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(57) Abstract 

The present invention provides apparatus, methods, 
and computer program products that can decrease the la- 
tency with which the coefficients of a function representa- 
tive of signal are determined. Specifically, the apparatus, 
methods, and computer program products of the present 
invention, taking advantage of the independence of sam- 
ples, updates each of the coefficients of the function as 
each sample is received. As such, when the final sample is 
received, the apparatus, methods, and computer program 
products of the present invention need only update each 
coefficient with the contribution of the last sample prior to 
outputting the coefficients. As such, the latency from the 
time the last sample is received and the availability of the 
coefficients is decreased. To further decrease the latency, 
in one embodiment, the apparatus, methods, and computer 
program products of the present invention prestore either 
all or a portion of the possible values of the contribution 
of a sample to each coefficient, such that. As such, when 
the sample is received, the apparatus, methods, and com- 
puter program products of the present invention evaluate 
the value of the sample and retrieve the appropriate value 
from the prestored values that corresponds to the coeffi- 
cient, sample, and value of the sample, thereby decreasing 
the time required to determine the coefficients. The ap- 
paratus, methods, and computer program products of the 
present invention also allow individual or subsets of the 
coefficients to be observed and also allow individual or 
subsets of the coefficients to be determined in varying resolutions 
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COMPUTATION OF DISCRETE FOURIER TRANSFORM 

5 FIELD OF THE INVENTION 

The present invention relates generally to the determination of coefficients of 
a function. More particularly, the apparatus, methods, and computer program 
products of the present invention relate to determining the coefficients of a function 
representative of an input signal as each sample of the signal is received to decrease 
10 latency in the determination of the coefficients. 

BACKGROUND OF THE INVENTION 

Signal processing is an important function of many electronic systems. In 
particular, in many electronic systems, data is transmitted in signal form. Further. 
1 5 some electronic systems analyze and monitor the operation of mechanical or chemical 
systems by observing the characteristics of signals, such as vibration signals and other 
types of signals, that are output from these systems. In light of this, methods have 
been developed to characterize signals such that information or data in the signal is 

available for data processing. 
20 As one example, in many electronic systems, time domain signals are typically 

transformed to the frequency domain prior to signal processing. A typical method for 
converting signals to the frequency domain is performed using Fourier Transforms. 
The Fourier Transform of a signal is based on a plurality of samples of the time 
domain signal taken over a selected time period, known as the base frequency. Based 
25 on these samples of the signal the Fourier Transform provides a plurality of 
coefficients, where the coefficients respectively represent the amplitude of a 
frequency that is a multiple of the base frequency. These coefficients of the Fourier 
Transform, which represent the signal in the frequency domain, are then used by 
electronic systems in processing the signal. 
30 Although Fourier Transforms are among some of the most widely used 

functions for processing signals, there are other functions that are either currently 
used or will be used in the future, as a better understanding of their applicability is 
recognized. These functions include Bessel functions. Legendre Polynomials. 
Tschebysheff Polynomials of First and Second Kind. Jacoby Polynomials. 
3f Generalized Laguerre Polynomials. Hermite Polynomials. Bernoulli Polynomials. 
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Euler Polynomials, and a variety of Matrices used in Quantum Mechanics, Linear 
Analysis functions, wavelets and fractals just to name a few. 

Although Fourier transforms and the other functions mentioned above are 
useful in determining characteristics of signals for use in data processing, there are 
5 some drawbacks to their use. Specifically, application of these functions to signals is 
typically computationally intensive. This is disadvantageous as it may require the use 
of specialized processors in order to perform data processing. Further, and even more 
importantly, the time required to perform the number of computations using these 
functions may cause an unacceptable delay for many data processing applications. In 
1 0 fact, a goal of many data processing systems is the ability to process data signals in 
real time, with no delay. 

For example, the Fourier Series is defined as an infinite series of coefficients 
representing a signal. To transform a signal using a Fourier Series would require an 
infinite number of computations. To remedy this problem, many conventional data 
1 5 processing systems use Discrete Fourier Transforms (DFT), as opposed to the infinite 
Fourier Series. The DFT is the digital approximation to the Fourier Series and is used 
to process digitized analog information. Importantly, the DFT replaces the infinite 
series of the Fourier Series with a finite set of N evenly spaced samples taken over a 
finite period. The computation of the DFT therefore provides the same number of 
20 coefficients as the samples received, instead of an infinite number of samples required 
by the Fourier Series. As such, use of the DFT provides the most satisfactory current 
means to process the signal. 

Because of the importance of reducing the time required to process signals, 
however, methods have been developed to further reduce the number of computations 
25 required to perform a DFT of a signal. Specifically, the DFT procedure computes 
each coefficient by a similar process. The process for a general coefficient is; 
multiply each sample by the sine or cosine of the normalized value of the independent 
variable times the angular rate and sum over all of the samples. This procedure 
defines N multiply-add steps for each of N coefficients, which in turn, equates to N" 
30 multiply-add computations per DFT. As many samples of a signal are typically 

required to perform an adequate approximation of the signal, the DFT of a signal is 
typically computational and time intensive. 

One of the methods developed to reduce the number of computations is the 
butterfly method, which reduces the number of computations from N 2 to N times log 
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(Tsl ). The butterfly method is based on the fact that many of the trigonometric values 
of the DFT are the same due to periodicity of the functions. As such, the butterfly 
method reduces the matrix associated with the DFT into N/2 two-point transforms 
(i.e.. the transforms representing each coefficient a„ and b n ). The butterfly method 
5 further reduces the redundant trigonometric values of the DFT. Although the 

butterfly method reduces the number of computations over the more traditional DFT 
method, it also adds complexity to the Fourier transformation of a signal. 
Specifically, the butterfly method uses a complex method for addressing the samples 
of the signal and the matrix containing the functions. This complexity can require the 
10 use of specialized processors and increase time for computation of the Fourier 
Transform. By its nature, the butterfly is a batch process, which does riot begin 
determination of the coefficients until after all of the samples have been received. As 
described later, this method causes latency in the determination of the coefficients of 
the function. 

1 5 An additional problem with the DFT, besides the number of computations 

required, is that the value of each coefficient of the DFT is a function of all the 
samples of the signal. Therefore, none of the coefficients of the DFT can be 
determined until all of the samples have been processed. Once the last sample of a set 
is received, the values of all of the coefficients can then be defined. As such, the time 

20 between the arrival of the last sample and the availability of the coefficients is 

referred to as the latency of the system. If the time for processing the coefficients is 
greater than the time to collect the set of samples, the system cannot operate in real 
time. 

Although no coefficient is defined until all of the samples have been received. 

25 there is an advantageous property of the DFT that has not been heretofore recognized 
in the prior art. This property is the independence of samples. In a set of samples 
being transformed in a DFT process, each sample makes a contribution to each 
coefficient based only on the sine or cosine of the applicable angle. This is illustrated 
in Appendix 1 . Specifically, each of the coefficients of the DFT, (i.e., AO, Al , A2. . . 

30 . and B0, Bl . B2, . . .). is the summation of the application of each sample to the sine 
and cosine functions associated with each coefficient. For example, the coefficient 
Al is the summation Al , + Al 2 + . . . Alg, which are the application of each sample 
to the cosine function associated with the Al coefficient. As each of the samples are 
related to each coefficient by addition, each sample is independent of the other 
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samples and can be used to update the coefficients prior to receipt of the other 
samples. 

Many conventional systems for determining the Fourier Transform of a signal 
do not recognize this independence of samples aspect of the DFT. Specifically. 
5 conventional systems that use the DFT typically first receive a number of samples N 
of a signal, and only after all of the samples have been received does the system 
generate each of the coefficients. As such, these conventional systems have an 
associated latency equal to the time required for the system to compute each of the 
coefficients after the last sample is received. This latency may be significant. For 
10 example, if a conventional system determines a DFT using N = 64 samples, then the 
number of computations is N 2 or 4096. For the Fast Fourier Transform (FFT), this is 
reduced to N times log (N) or 64(6) equals 364. 

Appendix 1 illustrates an example of a data processing system that waits until 
all of the samples have been received prior to determining the coefficients of the DFT. 
15 As can be seen, the data processing system illustrated in Appendix 1, first receives 
eight samples of the signal prior to beginning to process any of the coefficients of the 
Fourier Transform. Only after receipt of the samples does the system begin to 
calculate the coefficients. As latency is defined as the time between the receipt of the 
last sample and the time at which the coefficients are available, this data processing 
20 system has latency equal to the time required to perform all computations of the 

coefficients. As such, this data processing system cannot be used for real-time data 
processing. As real-time data processing or approximate real-time data processing is 
advantageous for use in many data processing systems, it would be desirous to 
provide apparatus and methods that decrease the time required to perform 
25 transformation of signals. 

An additional problem with many conventional data processing systems, such 
as the butterfly, is that the coefficients of the function cannot be independently 
observed due to the complexity of the system. Further, because the butterfly 
determines the coefficients in a batch method, as opposed to real time, individual 
30 coefficients can not be observed and tracked as each new sample is received. 

Because, the batch method of analysis adds latency, considerable processing must be 
employed with conventional systems to observe and track coefficients over time. 
Observance and tracking individual coefficients of a signal is advantageous for in- 
depth signal analysis. 

-4- 
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A still further problem with many conventional data processing systems is that 
these systems typically do allow for variation of the resolution of individual 
coefficients of the function. For example, the butterfly is configured to calculate each 
coefficient producing the same number coefficients as of samples. This may be 
5 disadvantageous in applications in which there is interest in only one or a subset of 
the coefficients, as the butterfly will spend time and resources determining 
coefficients of less importance to the same resolution as those coefficients of 
importance. In light of this, it would be desirous to provide apparatus and methods 
that allow for the tracking and observance of individual coefficients and also varying 
1 0 the resolution with which individual coefficients are calculated. 

SUMMARY OF THE INVENTION 

As set forth below, the apparatus, methods, and computer program products of 
the present invention overcome many of the deficiencies identified with processing 
15 signals using functions, such as Fourier Transforms. In particular, the present 
invention provides apparatus, methods, and computer program products that 
determine the coefficients of a function representative of an input signal with reduced 
latency, such that the coefficients of the function are made available within a 
decreased time from receipt of the last sample of the signal. The present invention 
20 also provides apparatus, methods, and computer program products that reduce the 
amount of data that must stored in order to determine the coefficients of a function, 
such that less complex hardware designs can be implemented. Further, the present 
invention provides apparatus, methods, and computer program products that allow 
individual coefficients to be tracked and observed and also allows individual 
25 coefficients or subsets of coefficients to be determined with differing levels of 
resolution. 

Specifically, in one embodiment, the present invention provides apparatus, 
methods, and computer program products that update at least one of the coefficients 
of a function prior to receipt of the last sample of the signal, such that the coefficients 
30 of the function may be determined with reduced latency. Further, in another 

embodiment, the apparatus, methods, and computer program products of the present 
invention update each of the coefficients of a function as each of the samples of the 
signal are received. As discussed previously, each of the samples of the signal affects 
the coefficients of the function independently of the other samples. The independent 
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nature of the samples permits the equations for each coefficient to be rearranged so as 
to group all of the contributions from each sample separately. The result is that the 
contributions of each sample can be computed when the sample is received and then 
added to each coefficient. 
5 In light of this, in one embodiment, the present invention includes an 

apparatus for determining the coefficients of a function representative of an input 
signal based on a predetermined plurality of samples of the input signal. The 
apparatus of the present invention includes a coefficient generator that receives each 
of the samples one at a time and updates at least one of the coefficients of the function 
1 0 prior to receipt of the last sample. 

In another embodiment, the apparatus of the present invention includes a 
coefficient generator that receives each of the samples one at a time and updates the 
coefficients of the function based on each sample as the sample is received without 
awaiting receipt of all samples. The coefficients are thus updated each time before 
15 the arrival of the next sample. As such, when the last sample is received, the only 

remaining computations are the determination of the contribution of the last sample to 
each coefficient. Therefore, the latency from receipt of the last sample until the 
coefficients are available is reduced. 

In a further embodiment of the present invention, the coefficient generator 
20 simultaneously updates each of the coefficients with a sample as it is received. As 
such, when the final sample is received, the coefficient generator simultaneously 
updates each of the coefficients and the latency between receipt of last sample and the 
availability of the coefficients is significantly reduced. 

In addition to decreasing the latency between receipt of the last sample and 
25 availability of the coefficients, the apparatus, methods, and computer program 

products of the present invention also reduce hardware needed for implementation. 
Specifically, as discussed the apparatus, methods, and computer program products of 
the present invention update each of the coefficients with the contribution of each 
sample as the sample is received. As such, retaining the sample after each of the 
30 coefficients has been updated is not required, thereby reducing the amount of storage. 
Further, the apparatus, methods, and computer program products of the 
present invention also decrease the time for performing computations by 
precalculating at least a portion of the functions associated with each coefficient and 
storing these pre-calculated values in memory for use in determining the coefficients 

-6- 
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for a given signal. Specifically, as discussed above and illustrated in Appendix 1 . 
each of the samples is related to each of the coefficients by a trigonometric function, 
where the value of the trigonometric function is based on the coefficient and the order 
that the sample was received in the plurality of samples. As the coefficient and the 
5 order in which the sample is received arc known before hand, the apparatus, methods, 
and computer program products of the present invention pre-calculate this portion of 
the trigonometric function for each sample and coefficient. As such, when each 
sample is received, the coefficient generator of the present invention need only 
multiply the sample by the prc-calculated value associated with the sample and 
10 coefficient. 

Specifically, in one embodiment, the present invention includes an apparatus 
having a coefficient generator that includes a memory device. Stored in the memory 
device are pre-calculated values representing the mathematical function associated 
with each sample and coefficient. In this embodiment of the present invention, when 
1 5 a sample is received, the coefficient generator accesses the memory device and 

multiplies the sample by the value representing the mathematical function associated 
with the sample and coefficient to thereby define a term of the coefficient. The 
coefficient generator further updates the coefficient by adding the term to the previous 
value of the coefficient. 
20 In an additional embodiment, the apparatus, methods, and computer program 

products may store each of the pre-calculated values in a memory device that includes 
an array having a plurality of cells, where each cell of the array stores a value 
representing the mathematical function associated with a respective sample and 
coefficient. Further, in this embodiment, each cell of the array has a unique address. 
25 which is designated by the respective coefficient and sample. As such, for each 

sample and coefficient, the coefficient generator of this embodiment of the present 
invention accesses the cell of the memory device using the address associated with the 
sample and coefficient, multiplies the sample by the stored value to thereby define a 
term of the coefficient, and thereafter updates the coefficient by adding the term to the 
30 previous value of the coefficient. 

In addition to reducing the required number of calculations by precalculating 
the function associated with each sample and coefficient, in one embodiment, the 
apparatus, method, and computer program product of the present invention also pre- 
calculates all the possible values of the magnitude of the sample with the 

-7- 
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trigonometric function associated with each coefficient and sample. As such, when a 
sample is received, the coefficient generator need only evaluate the value of the 
sample and retrieve the pre-calculated value associated with the value of the sample 
and the mathematical function for the sample and coefficient from the memory device 
5 and use the pre-calculated value to update the coefficient. 

For example, in one embodiment, the present invention includes an apparatus 
having a coefficient generator with first and second memory devices. The first 
memory device includes an array of cells with each cell associated with a respective 
sample and coefficient. Each cell contains a pre-calculated value corresponding to the 
1 0 combination of one of the finite number of possible values of the sample and the 
mathematical function associated with the respective coefficient and sample. The 
second memory device also has an array of cells for storing tokens. Each of the 
tokens represents a respective coefficient and sample. 

In operation, when a sample is received, the coefficient generator accesses the 
1 5 second memory device and for each coefficient retrieves the token associated with the 
coefficient and the sample and supplies the token to the first memory device. Further, 
the coefficient generator receives the value of the sample and based on the token from 
the second memory device and the value of the sample, retrieves the pre-calculated 
value stored in the cell of the first memory device that has an address comprised of 
20 the token and the value of the sample. The coefficient generator further updates the 
coefficient by adding the pre-calculated value from the first memory device to the 
previous value of the coefficient. 

In another embodiment, the coefficient generator includes a multiplier, adder, 
divider, or other gated functions, rather than a second storage device. In this 
25 embodiment, the tokens are provided by the gate to the first memory device for 
addressing the cells of the first memory device. In still another embodiment, a 
counter is decoded with or without the use of gates into tokens for addressing the 
second memory device, which may be conversion into values that feed a multiplier, 
adder, divider or other gated function, rather than a memory device. 
30 In addition to reducing the time for calculating the coefficient based on each 

sample by storing pre-calculated values, the present invention also provides apparatus, 
methods, and computer program products that minimizes the number of values that 
must be stored in the memory device and the size of the token needed to address the 
first memory device. Specifically, due to the trigonometric nature of some functions. 

-8- 
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some of ihe coefficients for some samples will have a mathematical value of zero. As 
the trigonometric function is dependent on the coefficient and sample number, these 
instances can be predetermined. Further, because the value for these instance is zero, 
there is no need to provide storage for these values in the first memory device, thereby 
5 reducing the size of the array of the memory device and the size of the token needed 
to address the first storage device. 

Specifically, in this embodiment of the present invention, the token also 
indicates if the value of the mathematical function associated with the respective 
sample and coefficient is zero. When a sample is received for which the 
1 0 trigonometric function for the sample and a coefficient is zero, the token associated 
with the sample and coefficient will so indicate. As such, when the coefficient 
generator accesses the token associated with the sample and coefficient, the 
coefficient generator will observe the token and update the coefficient by adding a 
zero to the previous value of the coefficient. 
1 5 In some embodiments, the coefficient generator further includes a null device, 

such as a pull down circuit. In this embodiment, if the token indicates that the 
mathematical function is zero, the null device replaces the output of the first memory- 
device with a zero value for addition to the coefficient. 

To further minimize storage, in one embodiment, the present invention 
20 provides apparatus, methods, and computer program products that stores only pre- 
calculated values corresponding to the combination of a respective sample and the 
magnitude of a respective mathematical function, without accounting for the sign of 
the mathematical function. Specifically, due to the periodic nature of some functions, 
some of the mathematical functions associated with the respective sample and 
25 coefficients have the same magnitude, but different signs. In this embodiment, of the 
present invention, only the magnitude of each value is stored in the memory device. 
Further, the sign of the value is indicated in the token. As such, less storage is needed 
for the values. 

In one embodiment of the present invention, the coefficient generator further 
includes an adder in electrical connection with the output of the first memory device. 
If the token indicates that the mathematical function is negative, the adder using twos- 
complement takes the negative of the magnitude of the mathematical function output 
by the first memory device. 

As detailed above, the present invention determines the coefficients of the 

-9- 
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function representative of signal by combining each sample upon receipt with the 
mathematical function associated with the sample and the coefficient. Further, as 
detailed above, the different combinations of the samples and coefficients are pre- 
calculated and stored in an addressable memory device. Typically, the tokens that 
address the cells of the memory device have bits indicating the coefficient and bits 
indicating the sample. While in the normal operation, the tokens and memory device 
are used to determine the coefficients of a function that is representative of a signal; 
these tokens and memory device may also be used to determine the coefficients of an 
inverse function of a signal. Specifically, in one embodiment, the coefficient 
generator further includes a selector in electrical connection with either the gate, 
counter, second memory device used to generate the tokens for addressing the first 
memory device. If the coefficients for an inverse function of a signal are desired, the 
selector alters the address indicated by the token such that the token addresses a cell 
of the first memory device containing a pre-calculated value representing an inverse 
mathematical function of the signal. 

As detailed above, the present invention determines the coefficients of the 
function representative of signal by combining each sample upon receipt with the 
mathematical function associated with the sample and the coefficient. Further, as 
detailed above, the different combinations of the samples and coefficients may be pre- 
calculated and stored in an addressable memory device or may be computed by a 
gated function with reference to a value associated with the token. Typically, the 
tokens that address the cells of the memory device are derived from state information 
obtained from the counter indicating the coefficient and the sample. While in the 
normal operation, the tokens and memory device are used to determine the 
coefficients of a function that is representative of a signal, these tokens and memory 
devices may also be used repetitively by adding bits to the counter at appropriate 
locations and thus service a multiplicity of channels. In this embodiment, additional 
coefficient memory cells maintain the additional coefficients, and a channel number 
may be output as a convenience to the user. It is still possible employ an electrical 
signal to determine the forward coefficients or to determine the inverse function of the 
input. 

Further, while in the normal operation, the tokens and memory device are used 
to determine the coefficients of a function that is representative of a signal, these 
tokens and memory devices may also be used repetitively by adding bits to the 
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counter ai appropriate locations and thus service a multiplicity of channels. In this 
embodiment, additional coefficient memory cells maintain the additional coefficients, 
and a channel number may be output as a convenience to the user. By letting 
consecutive samples be treated as different channels il is possible to thus produce 
5 interleaved transforms. The interleaved transforms may be sent to a second similar 
process to produce two-dimensional transforms, as one example. 

In a further embodiment, the coefficient generator receives samples from a 
plurality of different signals on different channels. In this embodiment, the 
coefficient generator, via the selector, may provide the coefficients of a function 
1 0 representative of one signal, while also providing the coefficients of an inverse 
funclion of another signal. 

As detailed above, the apparatus, methods, and computer program products of 
the present invention process a plurality of samples and generate the coefficients of 
the function based on the samples. In some embodiments of the present invention. 
1 5 after the plurality of samples have been received, the apparatus, methods, and 

computer program products of the present invention output the generated coefficients, 
reset the coefficients, and again take samples of the signal. In some embodiments, 
however, it may be advantageous to generate and output a complete set of coefficients 
as each new sample is received and processed. This is referred to as a Sliding 
20 Aperture Fourier Transform (SAFT). 

In this embodiment, the apparatus, methods, and computer program products 
of the present invention do not reset each of the coefficients to zero after the final 
sample of a plurality of samples has been received and the coefficients have been 
output. Instead, the apparatus, methods, and computer program products of the 
present invention replace the first sample of the previous plurality of samples with the 
next received sample. Using this new sample, the apparatus, methods, and computer 
program products of the present invention output a next set of coefficients. As such, 
instead of generating a set of coefficients for each "batch- of samples, the apparatus, 
methods, and computer program products of the present invention generates a set of 
coefficients each time a new sample is received, thereby providing new set of 
coefficients for each time a new sample is received. 

The present invention provides several apparatus, methods, and computer 
program products for generating a set of coefficients each time a new sample is 
received. In each of these embodiments, the apparatus, methods, and computer 
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program products of the present invention replace the first sample of the previous 
plurality of samples with the next sample received and then outputs the new 
coefficients. For example, in one embodiment, the apparatus, methods, and computer 
program products of the present invention initially store each of the samples as they 
5 are received and generates a first set of coefficients when the last sample of the 
plurality of samples has been received. Further, when a new sample of the input 
signal is received, after the predetermined plurality of samples has already been 
received, the apparatus, methods, and computer program products of the present 
invention apply the mathematical function associated with the coefficients to the 
] 0 sample and generate a term based on the new sample for each coefficient. To replace 
the new sample with the first sample of the plurality of the samples, the generated 
term of the new sample is subtracted from the term associated with the first sample of 
the predetermined plurality of samples that was previously stored in the memory 
device Following this subtraction, the coefficients are updated by the difference 
1 5 between the terms based upon the new sample and the first sample of the 
predetermined plurality of samples. 

In another embodiment of the present invention, to replace the new sample 
with the first sample of the plurality of samples, the apparatus, method, and computer 
program products of the present invention subtract the term based upon a first sample 
20 of the predetermined plurality of samples from each of the coefficients and adds the 
term based upon the new sample to each of the coefficients. 

In addition to outputting coefficients for each new sample received, the 
apparatus, methods, and computer program products of the present invention also 
allow individual of subsets of coefficients to be observed and tracked over time. 
25 Specifically, as stated above, the coefficient generator of one embodiment outputs 

coefficients for each new sample. This provides a user with a new set of coefficients 
in real or near real-time for observance. 

Further, as discussed, the apparatus, methods, and computer program products 
of the present invention update each of the coefficients of the function as each sample 
30 is received. As the coefficients are individually updated, they are more readily 

individually available for observance. Further, because each coefficient is updated 
individually, the number of updates made to each individual coefficient may be 
varied. As such, in one embodiment, the apparatus, methods, and computer program 
products of the present invention can vary the resolution to which either one or a 
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subset of coefficients are determined by varying the number of samples by which they 
are updated relative to the other coefficients. 

In addition, the present invention also provides methods and computer 
program products for reducing the number of values that must be stored to represent 
the possible mathematical terms of a function. Specifically, as illustrated above, time 
for performing computations can be conserved by precalculating and storing either 
portions of or all values associated with a system. However, it is often desirable to 
reduce the amount values that require storage to a minimum, such that standard 
memory devices may be used. 

In one embodiment, the present invention provides methods and computer 
program products that initially generate a first list of all possible mathematical terms 
of the function. For each mathematical term, the method and computer program 
product systematically compare each mathematical term in the list to all other 
mathematical terms in the list to determine which of the mathematical terms are 
redundant. Further, the unique mathematical terms of the function are stored in a 
second list all of the unique mathematical terms of the function, such that there are no 
redundant mathematical terms of the function in the second list. 

In one embodiment of the present invention, the function is at least periodic or 
reversing such that some of the mathematical terms of the function have the same 
magnitude and different signs. In this embodiment, the method and computer 
program product of the present invention compare the magnitude of each 
mathematical term in the list to the magnitude of each of the other mathematical terms 
in the list to determine which of the mathematical terms have the same magnitude. 
Further, the mathematical terms having unique magnitudes are stored in the second 
list. The method and computer program product of the present invention further 
includes creating a token associated with each mathematical term, where the token 
indicates the magnitude stored in the second list associated with the mathematical 
term and the sign associated with the mathematical term. 

In another embodiment of the present invention, at least one of the 
mathematical terms has a magnitude of zero. In this embodiment, the method and 
computer program product create a token associated with the mathematical term 
indicating that the mathematical term is zero such that the mathematical term is not 
stored in the second list. 
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In another embodiment, the function is representative of a signal and is 
defined by samples of the signal, where a sample of the signal is one of a finite 
number of possible values. In this embodiment, the method and computer program 
product generate the first list of all possible combinations of the possible values of the 
5 sample and the mathematical terms of the function. Further, each combination in the 
list is systematically compared to all other combinations in the list to determine which 
of the combinations are redundant. Based on this comparison, all of the unique 
combinations are stored in the second list, such that there are no redundant 
combinations in the second list. 

10 

BRIEF DESCRIPTION OF THE DRAWING 

Figure 1 is a block diagram of an apparatus for determining the coefficients of 
a function representative of an input signal based on a sample of the input signal using 
gate devices according to one embodiment of the present invention. 
1 5 Figure 2 is a block diagram of the operations performed to determine the 

coefficients of a function representative of an input signal based on a sample of the 
input signal according to one embodiment of the present invention. 

Figure 3 is a block diagram of an apparatus for determining the coefficients of 
a function representative of an input signal based on a sample of the input signal using 
20 at least one memory device according to one embodiment of the present invention. 

Figure 4 is a block diagram of the operations performed to reduce the number 
of values that must be stored to represent the possible mathematical terms of a 
function according to one embodiment of the present invention. 

Figure 5 is a graphic representation of the plot of coefficients determined 
25 using a Fourier Transform. 

Figure 6 is a block diagram of the operations performed to create a table of 
tokens, where each token represent a value of the function according to one 
embodiment of the present invention. 

Figure 7 is a block diagram of the operations performed to create a table of 
30 addressable values according to one embodiment of the present invention. 

Figure 8 is a block diagram of the operations performed to retrieve values 
from a table based on tokens according to one embodiment of the present invention. 
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Figure 9 is a block diagram of an apparatus for determining the coefficients of 
a function representative of an input signal based on a sample of the input signal using 
memory devices and gates according to one embodiment of the present invention. 

Figure 10 is a block diagram of the operations performed to determine the 
coefficients of a function representative of an input signal based on a sample of the 
input signal using memory devices and gates according to one embodiment of the 
present invention. 

Figure 1 1 is a block diagram of an apparatus for determining the coefficients 
of a function representative of an input signal based on a plurality of samples of the 
input signal according to one embodiment of the present invention. 

Figure 12 is a block diagram of the operations performed to determine the 
coefficients of a function representative of an input signal based on a plurality of 
samples of the input signal according to one embodiment of the present invention. 

Figure 13 is a block diagram of an apparatus for determining the coefficients 
5 of a function representative of an input signal based on a plurality of samples of the 
input signal using memory devices and gates according to one embodiment of the 
present invention. 

Figure 14 is a block diagram of the operations performed to determine the 
coefficients of a function representative of an input signal based on a plurality of 
0 samples of the input signal using memory devices and gates according to one 
embodiment of the present invention. 

Figure 1 5 is a block diagram of an apparatus for determining the coefficients 
of a function representative of an input signal based on a plurality of samples of the 
input signal using memory devices and gates, where for each sample received a set of 
>S coefficients are output according to one embodiment of the present invention. 

Figure 16 is a block diagram of the operations performed to determine the 
coefficients of a function representative of an input signal based on a plurality of 
samples of the input signal using memory devices and gates, where for each sample 
received a set of coefficients are output according to one embodiment of the present 
invention. 

DETAILED DESCRIPTION OF THE INVENTION 

The present invention now will be described more fully hereinafter with 
reference to the accompanying drawings, in which preferred embodiments of the 
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invention are shown. This invention may, however, be embodied in many different 
forms and should not be construed as limited to the embodiments set forth herein; 
rather, these embodiments are provided so that this disclosure will be thorough and 
complete, and will fully convey the scope of the invention to those skilled in the art. 
5 Like numbers refer to like elements throughout. 

As discussed above, data processing systems have been developed for 
determining the coefficients of a function that is representative of a signal. However, 
because many of these systems are complex and do not calculate the coefficients until 
all samples of the signal have been received, these systems do not provide immediate 
1 0 analysis of the signal. Further, because these conventional systems are complex, the 
individual coefficients are not readily accessible for observance and tracking. 
Further, these systems do not allow variation in the resolution of individual or 
selected subsets of coefficients. 

The present invention, on the other hand, provides apparatus, methods, and 
1 5 computer program products that can decrease the latency with which the coefficients 
of a function representative of signal are determined. Specifically, the apparatus, 
methods, and computer program products of the present invention, taking advantage 
of the independence of samples, updates at least one of the coefficients prior to receipt 
of the last sample, such that the latency in determining the coefficients is reduced. 
20 Further, in another embodiment, the apparatus, methods, and computer 

program products of the present invention update each of the coefficients of the 
function as each sample is received. As such, when the final sample is received, the 
apparatus, methods, and computer program products of the present invention need 
only update each coefficient with the contribution of the last sample prior to 
25 outputting the coefficients. As such, the latency from the time the last sample is 
received and the availability of the coefficients is decreased. 

To further decrease the latency, in one embodiment, the apparatus, methods, 
and computer program products of the present invention prestore either all or a 
portion of the possible values of the contribution of a sample to each coefficient. As 
30 such, when the sample is received, and especially the last sample, the apparatus. 

methods, and computer program products of the present invention evaluate the value 
of the sample and retrieve the appropriate value from the prestored values that 
corresponds to the coefficient, sample, and value of the sample, thereby decreasing 
the time required to determine the coefficients. Still further, in another embodiment, 
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the apparatus, methods, and computer program products of the present invention 
update each of the coefficients simultaneously. As such, when the last sample is 
received, the coefficients are updated simultaneously with the contribution of the last 
sample, and all of the coefficients are output. 
5 The apparatus, methods, and computer program products of the present 

invention also allow individual or subsets of the coefficients to be observed and also 
allows individual or subsets of the coefficients to be determined in varying 
resolutions. Specifically, as stated, the apparatus, methods, and computer program 
products of the present invention update each of the coefficients as each sample is 
1 0 received. As such, each sample is available for output when desired. Further, 
because the apparatus, methods, and computer program products of the present 
invention update each coefficient independent of the other coefficients, each 
coefficient can be updated to different resolutions. For example, one coefficient of 
interest may be updated with every sample, while another coefficient is only updated 

1 5 with every third sample. 

The apparatus, methods, and computer program products of the present 
invention may also reduce the amount and size of hardware needed to implement the 
processing system. Specifically, as stated, when a sample of the signal is received, 
the apparatus, methods, and computer program products of the present invention 

20 immediately update each of the coefficients with the contribution of the sample. As 
the samples are independent of each other, the sample is no longer needed after the 
coefficients have been updated with its contribution, and as such, the sample may be 
discarded. By discarding the sample after use, the processing system does not require 
additional memory storage for storing the samples or additional processing for 

25 retrieving the data. 

The present invention also provides methods and computer program products 
for reducing the number of values that must be stored to represent the possible 
mathematical terms of a function. Specifically, the method and computer program 
product of this embodiment of the present invention compares each of the possible 

30 mathematical terms of a function to the other mathematical terms. From this 

comparison, the method and computer program products reduce the number of values 
that should be stored. For example, in one embodiment, the mathematical function 
may be periodic, such that different values of the function have the same magnitude, 
but different signs. In this instance, the method and computer program product of the 
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present invention would only store the magnitude of the terms and use a token to 
represent the sign. In another embodiment, there may be values of the function thai 
are zero, (e.g.. cos(7i/2) and sin n = 0). In this embodiment, the method and computer 
program products do not store the value of zero, but instead use a token representing 
5 that the value is zero. 

For illustrative purposes, the various apparatus, methods, and computer 
program products of the present invention are illustrated and described below in 
conjunction with the characteristics of Fourier Series. It should be apparent, however, 
that the apparatus, methods, and computer program products of the present invention 
1 0 can be used with many different types of functions. For instance, the apparatus, 

methods, and computer program products may be used with functions such as Bessel 
functions, Legendre Polynomials, Tschebysheff Polynomials of First and Second 
Kind, Jacoby Polynomials, Generalized Laguerre Polynomials, Hermite Polynomials. 
Bernoulli Polynomials, Euler Polynomials, and a variety of Matrices used in Quantum 
1 5 Mechanics, Linear Analysis functions, wavelets and fractals. This list is by no means 
exhaustive and is provided as mere examples. The approach may be applied to any 
function that can be expressed as a sequence of values. The usefulness of the 
application of these and other functions hot listed above is quite general. This method 
provides a way to develop apparatus and methods for parallel computing and remove 
20 redundancy in a rote manner, which is compatible with machine execution. One 
implementation of the present invention would be in a general purpose computer 
program to examine each class of problem an write a minimal execution program or 
design an apparatus for the same function. In this application, it would be a 
programming aid. 

25 As discussed above with reference to Appendix 1 , an important concept of the 

present invention is the independence of the samples used to determine the 
coefficients of a function. The independence of samples can be illustrated in the 
context of Fourier Transforms. The Fourier Transform is based on the principle of 
orthogonality. As a Fourier Transform is applied in the DFT, it provides a means to 

30 evaluate the amplitude of the components of each frequency of a signal totally 
independently. The frequencies used in the computation are consecutive integral 
multiples of the base frequency. The base frequency is the time period required to 
take one set of samples. The samples of the signal are multiplied by each member of 
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the set of orthogonal functions and summed for one or a plurality of cycles of the base 
frequency. Each resulting coefficient is the amplitude of the real or imaginary part of 
one test frequency. Importantly, the computation of a coefficient is independent of 
the computation of the other cocff.cients. In a set of samples N, that are iransformed 
by the DFT. each sample contributes to each coefficient of the function based on 
either the sine or cosine of the applicable angle and normalization constants. The 
general equations for a Discrete Fourier Transform are provided below: 
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With reference to Appendix 1, the determination of the coefficients of a 
function using conventional DFT is illustrated. Initially, the DFT receives a 
preselected set of samples of a signal, (in this example N=8). The DFT next 
calculates all of the coefficients, (A* Ai, A 2 , A 3 , A* B,, B 2 , B 3 , and B 4 ) one at a time. 
The value of each sample is used one time in the computation of the coefficients. 
Each sample is multiplied by both the sine and cosine of the independent variable 
associated with each coefficient times a normalized rate. For example, the coefficient 
Al is the summation Al , + Al 2 + . . - Al., which are the application of each sample 
to the cosine function associated with the Al coefficient. As each of the samples are 
related to each coefficient by addition, each sample is independent of the other 
samples and can be used to update the coefficients prior to receipt of the other 
samples. 

In light of this independence of samples, the apparatus, methods, and 
computer program products of the present invention rearrange the terms as shown in 
Appendix 2. such that each of the coefficients are updated as each of the samples of 
the signal are received. This is different from the conventional method of Appendix 
1. which is a batch method that awaits until all samples have been received before 
calculating the coefficients. As described above and detailed below, by updating each 
of the coefficients as each sample is received, the apparatus, methods, and computer 
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program products of the present invention can reduce latency in generation of the 
coefficients, allow individual coefficients to be tracked or observed, and determine 
the coefficients with different resolutions. 

With reference now to Figure 1 , one embodiment for determining the 
5 coefficients of a function representative of an input signal based on samples of the 
input signal, according to the method illustrated in Appendix 2, is shown. The 
apparatus of this embodiment of the present invention includes a coefficient generator 
10. The coefficient generator includes a receiver 12 for receiving samples of an input 
signal. The coefficient generator also includes a first gate 14 in electrical 
1 0 communication with the receiver and a second gate 1 6 in electrical communication 
with the first gate. 

With reference to Figure 2 and Appendix 2, the operation of the coefficient 
generator is illustrated. In this illustration, the coefficient generators generates the 
coefficients based on N=8 samples of the signal. For each sample, the receiver 

1 5 receives a sample of the signal and inputs the sample to the first gate 12. (See step 
100). For each coefficient, the second gate receives two values, one 18 representing 
the number of the coefficient and the other 20 representing the sample number. Based 
on the coefficient number and the sample number, the second gate generates the 
orthogonal function portion of the signal. (See step 110). 

20 For example, as shown in Appendix 2, for the zeroth coefficient AO, the 

sample value is added to the coefficient, (i.e., AO + AO,). For the first sample and 
coefficient Al i, the orthogonal function is: 

cos (27iC„S n /N) 

where: 

25 C n = coefficient number; 

S„ = sample number; and 
N= number of samples. 
To calculate the term for the first coefficient and first sample, the second gate receives 
the coefficient number 18 and the sample number 20. Based on this, for the first 
30 sample S n and the first coefficient C n . the second gate generates cosQti- 1 • 1/8 ) or 
cos(27r/8) and outputs this value to the first gate. (See step 110). 

The first gate, in turn, receives the value from the second gate and the value of 
the sample from the receiver. Based on these values, the first gate generates a term 
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representing the contribution of the sample to the coefficient, (i.e., S.cosQn/g)). (See 
step 120). This term is then added to the coefficient Al , (i.e.. Al + Al ,)• (See step 
130). This is repeated for each coefficient. (See steps 140 and 150). 

The discussion above illustrates the updating of each coefficient one at a time 
5 with each sample. However, it must be understood that the coefficient generator 
could only update one of the coefficients prior to receipt of the last coefficient and 
thereby decrease the latency in determining the coefficients. Further, it must be 
understood that the coefficient generator could update all of the coefficients with each 
sample simultaneously. For example, the coefficient generator could contain a 
10 plurality of first and second gates all connected to the receiver. In this embodiment, 
the sample is supplied to each set of gates simultaneously, and each set of gates, in 
turn, generates the term for each coefficient representing to the contribution of the 
sample to each coefficient simultaneously, and each coefficient is updated 
simultaneously. This is referred to as parallelism and is advantageous as it allows all 
1 5 coefficients to be updated simultaneously. Parallelism is the typical application of the 
coefficient generator. Specifically, the coefficient generator is typically implemented 
to update all coefficients simultaneously. Further, in some instance, the coefficient 
generator is configured to received inputs from several channels, for which the 
coefficient generator generates a set of coefficients for each channel. However, in 
20 many of the embodiments below, the coefficient generator is illustrated as updating 
each coefficient sequentially and with only one channel for sake of clarity. 

Figure 1 illustrates the determination of the coefficients based on the use of 
gates, such as multipliers, adders, dividers, or other gated functions. Figure 3 
illustrates the determination of the coefficients using at least one memory device. Use 
25 of memory devices, as opposed, to gates may be advantageous as many of the values 
that must be calculated to determine the coefficients may be prestored in the memory 
devices. This, in turn, may save time in determining the coefficients. 

With reference to Figure 3. the coefficient generator of this embodiment 
includes a receiver 12 for receiving samples of a signal. The coefficient generator 
30 also includes a first memory device 22 in electrical communication with the receiver 
and a second memory device 24 in electrical communication with the first memory 
device. In one embodiment of the present invention, the second memory device 
includes an array of cells, where each cell contains a pre-calculated value representing 
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the orthogonal function portion of the signal for each sample and coefficient. For 
example, the second memory device includes a cell for the orthogonal function 
portion of the signal for the first sample and coefficient equal to cos(27tC n S n /N ) or 
cos(2ti/8). In this embodiment, the first memory device may be a multiplier. 
5 With reference to Figure 2 and Appendix 2. in operation in this embodiment, 

for each sample, the receiver receives a sample of the signal and inputs the sample to 
the first memory device 22. (See step 100). For each coefficient, the second memory- 
device receives a token representing the address of the cell containing the orthogonal 
function portion of the signal for the sample and coefficient. This token is provided 
10 by the inputs, 18 and 20, where one portion of the token is the coefficient number C n 
and the other portion is the sample number S„. Based on the token, the second 
memory device retrieves the value associated with the coefficient and sample and 
outputs the value to the first memory device. (See step 110). The first memory 
device, in turn, receives the value from the second memory device and the value of 
1 5 the sample from the receiver. Based on these values, the first memory device 

generates a term representing the contribution of the sample to the coefficient, (i.e., 
Sicos(27t/8), for the first sample and coefficient). (See step 120). This term is then 
added to the coefficient, (i.e., Al + Al ,). (See step 130). This is repeated for each 
coefficient. (See steps 140 and 150). 
20 In some embodiments of the present invention, the sample received from the 

receiver is one of a number of finite values. Since the orthogonal function portion for 
each sample and coefficient is previously known, (i.e., (27tC n S n /N)). and the sample 
can only be one of a finite number of values, values representing each sample value, 
sample number, and coefficient number can be pre-calculated and prestored. As such. 
25 when a sample is received, the term representing the sample's contribution to each 

coefficient can be determined by looking up the value in the memory device based on 
the value of the sample, sample number, and coefficient number. 

In light of this, in one further embodiment, the first memory device is a 
memory device containing an array of cells. Each cell of the first memory device 
30 includes a pre-calculated value representing each sample value, sample number, and 
coefficient number. For each coefficient and sample, the memory device contains a 
group of cells, each having the orthogonal function associated with the coefficient and 
sample multiplied by a possible value for the sample. For example, for the first 
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sample and coefficient, there are a group of cells having a value of S,cos(2n/8). where- 
each cell represents the value for a different possible value of Si . Additionally, the 
second memory device has an array of cells each having a token representing the 
orthogonal function portion for each sample and coefficient. 
5 In operation, with reference to Figure 2. for each sample, the receiver receives 

a sample of the signal and inputs the sample to the first memory device 22. (See step 
100). For each coefficient, the second memory device receives from the inputs, 18 
and 20, values representing the address of the cell containing the token representing 
the orthogonal function portion of the signal for the sample and coefficient. The 
1 0 second memory device retrieves the token associated with the coefficient and sample 
and outputs the token to the first memory device. (See step 1 10). The first memory 
device, in turn, receives the token from the second memory device and the value of 
the sample from the receiver. Based on the token and the value of the sample, the 
first memory device looks up the cell in the array corresponding to these values and 
1 5 outputs a term representing the contribution of the sample to the coefficient, (i.e., 
Sicos(27t/8), for the first sample and coefficient). (See step 120). This term is then 
added to the coefficient, (i.e., Al + Al ,). (See step 130). This is repeated for each 
coefficient. (See steps 140 and 150). 

Again, it must be understood that the apparatus of this embodiment may 
20 operate in a parallel configuration to update each coefficient simultaneously by 

providing a plurality of first and second memory devices for each coefficient that are 
all connected to the receiver. In this embodiment, each first and second memory 
device receives the sample simultaneously and is addressed appropriately such that 
each set of first and second memories address values for the different coefficients. 
25 Thus, the contribution of the sample to each coefficient is determined in parallel and 
simultaneously. 

With reference to Figure 3, in one additional embodiment, the coefficient 
generator may include a counter 26 in electrical communication with the second 
memory device 24. The counter may be incremented by a clock, not shown, that is 
30 timed to allow calculations to be made. The counter may include two outputs. 18 and 
20. which represent the coefficient number and sample number for addressing the 
second memory device. In operation, for each sample, the sample number is held 
constant, while for each cycle or plurality of cycles of the clock, the counter 
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increments the coefficient number. This, in turn, addresses the second memory 
device for determining the contribution of the sample to each coefficient. After, all of 
the coefficients have been calculated for that sample, the sample number of the 
counter is incremented, and the coefficient number is reset, such that the next sample 
5 is now evaluated for each coefficient. 

As detailed above, to reduce time for calculations, one embodiment of the 
present invention uses memory devices to store pre-calculated values and tokens to 
address the memory devices. An important concern in many electronic designs is the 
desire to minimize the number of components needed to operate the circuit and also 
1 0 the need to use off-the-shelf components wherever possible. In light of this, methods 
are needed that evaluate the need aspects of a design and determine design solutions 
that minimize the number of components and allow for the use of standard 
components. 

As such, the present invention provides methods and computer program 

1 5 products for reducing the number of values that must be stored to represent the 

possible mathematical terms of a function. This method is illustrated with reference 
to Figure 4 and an example of a method of reducing the number of values that must be 
stored in the memory device of the coefficient generator is shown in Figure 3. 

With reference to Figure 4, first an empty list is created, (see step 200), and all 

20 possible mathematical terms of a function are stored in a matrix. (See step 210). For 
example, in many mathematical functions, such as a Fourier Series, a specific array of 
values must be multiplied by a set of data. If the data is N-bit binary numbers and 
there are M numbers in the array, the number of possible products that might be 
formed is two to the power of N times M, ( 2 NxM ). For example, if a Fourier Series is 

25 based on 64 samples to generate 64 coefficients, there are 4096 trigonometric 

functions to be evaluated and multiplied by the samples. If the samples are each 1 2 
bits in length, there are 4906 possible sample values. To pre-calculate and store the 
product of each of the possible sample values times the value of the trigonometric 
function for all 4096 possible sample values would require 16, 777, 216 stored 

30 products, which would require a rather large memory device. 

With reference to Figure 4. to reduce the number of stored values, the method 
and computer program product of the present invention place all the possible values in 
a matrix, (see step 210). and systematically compares each mathematical term in the 
list to all other mathematical terms in the list to determine which of the mathematical 
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terms are redundant. (See steps 220 and 240). If the value is unique, it is stored in the 
generated list. (See step 250). This repeated for all values, (see step 260), and the 
total number of values is output. (See step 270). 

For example, for the Fourier Series, because of the properties of sine and 
5 cosine, there are only 32 different actual values required to be stored. This analysis is 
based on an evaluation of the sine and cosine functions that are typically used in 
Fourier Transforms. Specifically. Figure 5 illustrates two graphs plotting 4096 
evaluations of sine and cosine for the coefficients of a Fourier Transform using 64 
samples and 64 coefficients. These graphs illustrate that there is only a finite set of 
1 0 values. This analysis is based on the fact that each value is related to a polarity, plus 
or minus. If the plus or minus of the values are signified by tokens, the absolute value 
of the functions are all that needs to be stored. In doing so. the requirement for 
memory can be reduced from 256K to 128K. 

The number of values stored can also be reduced if the incoming sample value 
1 5 code representing the value of the sample is in a signed form, (i.e., positive or 

negative), about zero so that there is one sign bit and the remaining 1 1 bits are the 
absolute value of the 12 bit input. An 1 1 bit number only requires half as many 
memory locations for storage as 12 bits. As such, the size of the memory can be 
reduced to 64K by transforming the 12 bit value into an 1 1 bit value and a 1 bit sign 
20 and handling the sign bit in some logic, which can similarly support the tokens. 

As discussed there are 32 different values, which require 32 different tokens 
that must be stored. If the number of tokens could be reduced to 1 6, then there would 
be 16 values times 2048 possible sample value, which is 32K. This can be 
accomplished by observing that one of the values is zero and all 4096 values 
25 associated with it become zero. Instead, of providing tokens for the zero values, the 
token itself can contain a bit dedicated to zero. As such, a set of 1 6 tokens can be 
used, where 4 bits are the address, a sign bit to represent the sign of the value, and a 
zero bit to represent when the value is zero. 

As illustrated, the method and computer program products of the present 
30 invention can be used to reduce the number of values that must be stored. This, in 
turn, allows for the use of minimum and standard hardware. For example, in the 
above example where 64 samples of a signal are taken using a 12 bit sample code, the 
first memory device for storing all of the pre-calculated values can be reduced to a 
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128K memory, and the second memory for storing the tokens can be reduced to an 8K 
memory. 

Although the method and computer program products of the present invention 
for reducing the number of stored values are illustrated in the context of a Fourier 
5 Series with a predecribed number of samples and sample bit size, it must be 

understood that the methods and computer program products for reducing the number 
of required values that must be stored can be used with any function, number of 
prescribed samples, and/or sample bit size. 

After the number of stored values has been determined, the values should be 
10 addressed with tokens that are stored in the second memory device. With reference to 
Figure 6, to create addresses/tokens for storage, the method initially applies an 
address to a value, (see steps 300 and 310). A token related to the address is then 
selected. (See step 320). The method next checks to see if all values have been 
addressed. (See step 330). If not, the method increments the address in any order, 
15 (see step 340). Once all values have been addressed, they are loaded into memory. 
(See step 350). Similarly, once a set of values is known for the tokens, it is common 
to find an arrangement of adders or other gating that replaces the table with the same 
response to each address and a saving in the number of transistors or whatever 
measure is most meaningful in the technology being implemented. This is called a 
20 gated function rather than a table. 

With reference to Figure 7, in addition to creating and storing tokens, the pre- 
calculated values should also be loaded into the first memory device. Specifically, for 
each possible sample value, the method and computer program products of the present 
invention, takes a first token and applies the value of the token and a possible value of 
25 the sample to the function to create a pre-calculated value of the function for the 
sample value. (See step 400 and 410). The pre-calculated value is then stored in 
memory. (See step 420). The method next checks to see if all values have been 
addressed. (See step 430). if not, the method increments the address in any order, 
(see step 440). Once all values have been addressed, they are loaded into memory. 
30 (See step 450). Similarly, once a set of values is known for the tokens, it is common 
to find an arrangement of multipliers or other gating that replaces the table with the 
same response to each address and a saving in the number of transistors or whatever 
measure is most meaningful in the technology being implemented. This is called a 
gated function rather than a table. 
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Figure 3, described above, illustrates use of memory devices and tokens to 
determine the coefficient of a function. Figure 8, however, illustrates a more general 
use of the memory devices and tokens developed above in Figures 4. and 6-7. 
Specifically, to use the memory device and tokens to determine a value, the address 
5 representing a desired token is applied to the second memory device, (see step 500), 
and the token is retrieved. (See step 510). The token is then applied to the first 
memory device, along with the value of the sample to create the address for accessing 
the first memory device. (See steps 520 and 530). If the token includes a sign bit or 
zero bit that are set, the value associated with token in the first memory device is 
1 0 altered appropriately. (See step 540). Finally, the value is output. (See step 550). 

As discussed above, the number of values that must be stored to calculate the 
coefficients of function can be decreased by removing redundant values, storing only 
the magnitude of the values, and using token bits to signify when a value is zero or the 
sign of a value. Figure 9 provides an illustrative embodiment for determining the 
1 5 coefficients of a function using a first memory device having the minimum number of 
values stored, a second memory device with tokens that include bits for indicating 
sign and zero, and a signed input value. As with the previous embodiment, the 
coefficient generator 10 of this embodiment includes first and second memory 
devices, 22 and 24. Both of the memory devices include arrays of cell for storing 
20 values. The second memory device includes tokens representing the coefficient and 
sample number, and the first memory device includes all of the possible unique values 
of the sample combined with the orthogonal function portion for each sample and 
coefficient. For example, for the first sample S, and second coefficient C,. the token 
stored in the second memory device designates the sample number and coefficient 
25 number, S , and C, . Stored in the first memory device is a number of cells each 
having a value defined by the equation (S.cos (2tiC„S„/N) or (S.cos (2ti/N)). with 
each cell storing the application of a possible value of the sample S, to the equation. 

Additionally, the coefficient generator of this embodiment also includes a first 
AND gate 28 in electrical communication with the receiver 12. the output of the 
30 second memory device, and an input of the first memory device. The coefficient 
generator also includes a second AND gate 30 connected to the output of the first 
AND gate 28 and an XOR gate 32. Connected to the output of the second AND gate 
30 is an adder 36, typically implemented so as to take the twos complement of a 
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signal. The XOR gate 32 is in electrical communication with the output of the second 
memory device and a gate combination 40 to be discussed later. The coefficieni 
generator of this embodiment also includes a null device or pull down 34 in electrical 
communication with the output of the first memory device. 
5 Importantly, to reduce the number of values that must be stored, the sample 

received by the receiver is in a 12 bit code, where one of the bits is a sign bit. As 
discussed, by reducing the bit representation of the sample to 1 1 bits and using one bit 
for the sign, storage space is reduced. To this end, in some embodiments, the 
coefficient generator also includes a code converter 38 in electrical communication 
1 0 with the receiver 12. If the sample output by the receiver is not in the proper 1 2 bit 
format, the code converter will convert the sample into a 12 bit value having 1 1 bits 
representing the value and 1 bit for the sign. 

The coefficient generator of this embodiment also uses a 6 bit token stored in 
the second memory device to address the values stored in the first memory device. 
15 Importantly, to decrease the number of values that must be stored, one of the bits 
represents the sign of the number and one of the bits represents whether the value is 
zero. The tokens operate in conjunction with the second AND gate 30 and adder 36 
to take the negative of the output of the first memory device, if the sign bit of the 
token indicates the negative of the value. Further, the null or pull down device 34, the 
20 zero bit of the token, and the AND gate 28 operate to null or zero the output of the 
first memory device, if the token indicates that the value should be zero. 

With reference to Figure 10, in operation in this embodiment, for each sample, 
the receiver receives a sample of the signal and inputs the sample to the first memory 
device 22. (See step 600). For each coefficient, inputs, 18 and 20, are provided to the 
25 second memory device representing the sample number and coefficient number. (See 
step 610). Based on the inputs, the second memory device outputs a token having 4 
bits representing the sample and coefficient number, 1 bit representing whether the 
value is negative, and 1 bit representing whether the value is zero or not. (See step 
620). The first memory device, in turn, receives the token from the second memory 
30 device and the value of the sample from the receiver. Based on these values, the first 
memory device generates a term representing the contribution of the sample to the 
coefficient, (i.e., S|COs(2n/8), for the first sample and coefficient). (See step 630). 
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Additionally, the sign bit of the sample and the output of the sign bil of the 
token are supplied to the second AND gate 30. If either the sign of the signal is 
negative or the sign bit of the token is set, the second AND gate outputs a carry bit to 
the adder 36. The adder will make the output of the first memory device negative. 

5 (See steps 640 and 650). 

Likewise, the token and the signal are both provided to the first AND gate 28. 
If either the signal or the token indicates a zero value, a zero value is output by the 
first AND gate 28. The zero value is sent to the second AND gate 30, which prohibits 
the second AND gate 30 from negating the signal. Further, a zero value is output to 
1 0 the first memory device, which disables the first memory device. Due to the 

disablement of the first memory device, the null or pull down device 34 outputs a zero 
value representing the value of the coefficient. (See steps 660 and 670). The term of 
the coefficient is then output. (See step 680). 

As illustrated in Figure 9, in one embodiment, the coefficient generator further 
1 5 includes a counter 26 in electrical communication with the second memory device. 
The counter may be incremented by a clock, not shown, that is timed to allow 
calculations to be made. The counter may include two outputs, 18 and 20, which 
represent the coefficient number and sample number for addressing the second 
memory device. In operation, for each sample, the sample number is held constant, 
20 while for each cycle or plurality of cycles of the clock, the counter increments the 
coefficient number. This, in turn, addresses the second memory device for 
determining the contribution of the sample to each coefficient. After all of the 
coefficients have been calculated for that sample, the sample number of the counter is 
incremented, and the coefficient number is reset, such that the next sample is now 
25 evaluated for each coefficient. 

Further, and importantly. Figure 9 also illustrates another aspect of the present 
invention. As discussed above, the apparatus, methods, and computer programs 
products of the present invention determine the coefficients of a function 
representative of an input signal based on a predetermined plurality of samples of the 
30 input signal. However, the apparatus methods, and computer program products may 
also determine the coefficients representing an inverse function of the signal. For 
example, many data processing systems are equipped to perform both a DFT and an 
inverse DFT of the signal. 
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The inverse DFT is essentially performing the DFT in the reverse sense. As 
the first memory device includes all of the possible values of the DFT. the inverse 
DFT can be determined by merely addressing the values in the first memory device 
that correspond to the values of the inverse DFT. With reference to Figure 9. to 
5 implement an inverse DFT. the coefficient generator further includes a third gate 40 
having and XOR and NOT gate. The third gate has inputs connected to the sign bit of 
the 12 bit signal and an input for indicating when to perform an inverse function 44. 
The output of the third gate is connected to XOR gate 32, along with the output of the 
second memory device. Further, the coefficient generator also includes a selector or 
10 crossbar 42 in electrical communication with the inputs, 18 and 20, to the second 
memory device. The crossbar is also connected to the input 44 indicating whether 
perform an inverse function. 

In operation, the inverse function, (e.g.. inverse DFT), operates similar to the 
operation to determine the function (e.g.. DFT), as discussed in Figure 10. Except 
1 5 that the selector or crossbar switches the address input lines to the first memory 

device. Specifically, if the coefficients for an inverse function of a signal are desired, 
the selector alters the address indicated by the token such that the token addresses a 
cell of the first memory device containing a pre-calculated value representing an 
inverse mathematical function of the signal. Further, the third gate 40 operates in 
20 conjunction with the second AND gate 30 to negate the signal when either the 

mathematical function or input signal are negative. As such, the apparatus, methods, 
and computer program products of the present invention can determine the function or 
the inverse function using the same components and stored values, merely by 
switching the values that are addressed to perform the inverse function. 
25 As provided above, the apparatus, methods, and computer program products 

of the present invention determine the coefficients of a function representative of a 
signal by updating each coefficient as each sample is received. Figures 1, 3. and 9 
illustrate the updating of the coefficients for one sample. Figure 1 1 . discussed in 
detail below, illustrates the determination of the coefficients based on a plurality of 
30 samples, and in particular, illustrates the updating of each coefficient for each sample 
received. 

Similar to previous embodiments, the coefficient generator 10 of this 
embodiment includes first and second memory devices. 22 and 24. Both of the 
memory devices include arrays of cells for storing values. The second memory 

-30- 



BNSOOCID: <WO 0067146A1 I > 



WO 00/67146 PCT/USOO/l 1366 

device includes lokens representing the coefficient and sample number, and the first 
memory device includes all of the possible unique values of the sample combined 
with the orthogonal function portion for each sample and coefficient. Although any 
system or device may be used for addressing the second memory device, the present 
5 embodiment illustrates a counter 26 to address the second memory device. 

The coefficient generator of this embodiment further includes an adder 44 in 
electrical communication with the output of the first memory device. Connected to 
the adder 44 is a crossbar 46 and a third memory device 48. The coefficient generator 
also includes a null or pull down device 50 in electrical communication with the 
1 0 crossbar, and an AND gates. 52 and 54. connected to the output of the counter. 

With reference to Figure 1 1 . in operation in this embodiment, for each sample, 
the receiver receives a sample of the signal and inputs the sample to the first memory 
device 22. (See step 700). For each coefficient, inputs. 18 and 20, are provided to the 
second memory device representing the sample number and coefficient number from 
1 5 the counter. (See step 710). Based on the inputs, the second memory device outputs 
a token. (See step 720). The first memory device, in turn, receives the token from the 
second memory device and the value of the sample from the receiver. Based on these 
values, the first memory device generates a term representing the contribution of the 
sample to the coefficient. (See step 730). The term is next provided to the adder 44, 
20 which also receives the previous value of the coefficient from the third memory 

device 48. The third memory device is also connected to the second memory device. 
The token from the second memory device addresses the coefficient stored in the third 
memory device, which, in turn, is output to the adder for adding to the term. The term 
is added to the existing coefficient by the adder. (See step 740). 
25 After, the coefficient is updated, the coefficient generator next determines 

whether the last sample has been processed. (See step 750). Specifically, the AND 
gate 52 is connected to the six most significant bits of the counter, which designate 
the sample number. If the sample number is the last sample number of the set. (in this 
case the 64th sample), the six most significant bits of the counter will be all ones. 
30 When all ones are input in to the AND gate 52. the AND gate outputs a one indicating 
that the last sample has been received. 

If the last sample has not been received, the crossbar 46 directs the updated 
coefficient from the adder 44 to the third memory device 48. where the updated 



o i - 



BNSDOCID <WO 0067 1 46A 1.1 > 



WO 00/67146 PCT/US00/11366 
coefficient is stored. (See step 760). The null or pull down device 50 also outputs a 
zero on the output indicating that the coefficients have not been calculated. 

On the other hand, if the last sample has been received, the crossbar 46 directs 
the updated coefficient from the adder 44 to the output. (See step 770). Further, the 
5 null or pull down device 50 is directed by the cross bar to zero or null the value stored 
in the third memory device as a reset. Further, the AND gate 54 indicates that the 
coefficient value output is a valid value, instead of zero. 

The above steps are repeated for each coefficient until all of the coefficients 
have been updated with the sample. (See step 780 and 790). Further, the process is 
1 0 repeated for each sample, until all samples are received and each coefficient is 
updated. (See step 795). 

Figure 1 1 also illustrates another aspect of the present invention. Specifically, 
in one embodiment, the coefficient generator of the present invention is connected to 
a plurality of signal channels, such that the coefficient generator determines 
1 5 coefficients for functions representing signals located on each channel. In this 

embodiment, the counter also outputs a count value indicating the channel for which 
the coefficient generator is currently processing a signal. The channel number and 
coefficient number are output on lines, 56 and 58. The coefficient generator operates 
similar to the previous embodiments. Specifically, the coefficient generator is first 
20 connected to the first channel, where it receives a sample and updates the coefficients 
associated with the first channel. The coefficient generator goes to each channel and 
receives a sample and updates the coefficients associated with the signal on that 
channel. This is repeated until all of the samples for all channels have been received 
and the coefficients for the signal on each channel have been updated. In another 
25 embodiment, the coefficient generator may receive and process all the samples for 
one channel before switching to the next channel. 

As discussed previously, it sometimes advantageous to reduce the amount of 
data that must be stored by eliminating redundant values, storing only the magnitude 
of the values, and using tokens to designate sign or whether the value is zero. As 
30 such. Figure 1 3 illustrates the coefficient generator of Figure 1 1 with the addition of 
gates to reduce the amount of values that must be stored. Specifically, similar to the 
previous embodiment, the coefficient generator 10 of this embodiment includes first 
and second memory devices, 22 and 24. Both of the memory devices include arrays 
of cell for storing values. The second memory device includes tokens representing 

-32- 



BNSOOClO: <WO OOS7146A1 I > 



WO 00/67146 PCT/USOO/11366 
the coefficient and sample number, and the first memory device includes all of the 
possible unique values of the sample combined with the orthogonal function portion 
for each sample and coefficient. Although any system or device may be use for 
addressing the second memory device, the present embodiment illustrates a counter 
5 26 to address the second memory device. 

The coefficient generator of this embodiment further includes an adder 44 in 
electrical communication with the output of the first memory device. Connected to 
the adder 44 is a crossbar or selector 46 and a third memory device 48. The 
coefficient generator also includes a null or pull down device 50 in electrical 
10 communication with the crossbar, and a NAND gate 52 and AND gate 54, connected 
to the output of the counter. 

Additionally, the coefficient generator of this embodiment also includes a fust 
AND gate 28. a second AND gate 30, and an XOR gate 32. Connected to the output 
of the second AND gate 30 is an adder 36, typically implemented so as to take the 
15 twos complement of a signal. The XOR gate 32 is in electrical communication with 
the output of the second memory device and a gate combination 40. The coefficient 
generator of this embodiment also includes a null device or pull down 34 in electrical 
communication with the output of the first memory device. 

The coefficient generator also includes a code converter 38 in electrical 
20 communication with the receiver 12 for converting the input signal, if necessary, to a 
12 bit value having 1 1 bits representing the value and 1 bit for the sign. The 
coefficient generator of this embodiment also uses a 6 bit token stored in the second 
memon- device to address the values stored in the first memory device. As with the 
previous embodiment, the tokens operate in conjunction with the second AND gate 30 
25 and adder 36 to take the negative of the output of the first memory device, if the sign 
bit of the token indicates the negative of the value. Further, the null or pull down 
device 34 and the zero bit of the token operate to null or zero the output of the first 
memon device, if the token indicates that the value should be zero. 

Still further, the coefficient generator includes a first 60 latch for latching the 
30 input signal and a second latch 62 for latching out the output coefficient values. The 
coefficient generator also includes an input 44 and gate combination 40 for using the 
coefficient generator to determine the coefficients of an inverse function of the signal. 
Further, the coefficient generator includes reset device 64 for resetting the memory 
and outputs 56 and 58 for outputting the coefficient and channel number. 
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With reference to Figure 14. in operation in this embodiment, for each sample, 
the receiver receives a sample of the signal and inputs the sample to the first memory 
device 22. (See step 800). For each coefficient, inputs, 18 and 20, are provided to the 
second memory device representing the sample number and coefficient number. (See 
5 step 810). Based on the inputs, the second memory device outpuls a token having 4 
bits representing the sample and coefficient number, 1 bit representing whether the 
value is negative, and 1 bit representing whether the value is zero or not. (See step 
820). The first memory device, in turn, receives the token from the second memory 
device and the value of the sample from the receiver. Based on these values, the first 
1 0 memory device generates a term representing the contribution of the sample to the 
coefficient. (See step 830). 

Additionally, the sign bit of the sample and the output of the sign bit of the 
token are supplied to the second AND gate 30. If either the sign of the signal is 
negative or the sign bit of the token is set, the second AND gate outputs a carry bit to 
1 5 the adder 36. The adder will make the output of the first memory device negative. 
(See steps 840 and 850). 

Likewise, the token and the signal are both provided to the first AND gate 28. 
If either the signal or the token indicates a zero value, a zero value will be output by 
the first AND gate 28. The zero value is sent to the second AND gate 30, which 
20 prohibits the second AND gate 30 from negating the signal. Further, a zero value is 
output to the first memory device, which disables the first memory device. Due to the 
disablement of the first memory device, the null or pull down device 34 outputs a zero 
value representing the value of the coefficient. (See steps 860 and 870 ). The term of 
the coefficient is then output. 
25 The term is next provided to the adder 44 ? which also receives the previous 

value of the coefficient from the third memory device 48. The third memory device is 
also connected to the second memory device. The token from the second memory 
device addresses the coefficient stored in the third memory device, which, in turn, is 
output to the adder for adding to the term. The term is added to the existing 
30 coefficient by the adder. (See step 880). 

After, the coefficient is updated, the coefficient generator next determines 
whether the last sample has been processed. (See step 900). Specifically, the AND 
gate 52 is connected to the six most significant bits of the counter, which designate 
the sample number. If the sample number is the last sample number of the set, (in this 
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case the 64th sample), the six most significant bits of the counter will be all ones. 
When all ones are input to the AND gate 52. the AND gate outputs a one indicating 
that the last sample has been received. 

If the last sample has not been received, the crossbar or selector 46 directs the 
5 updated coefficient from the adder 44 to the third memory device 48. where the 
updated coefficient is stored. (See step 900). The null or pull down device 50 also 
outputs a zero on the output indicating that the coefficients have not been calculated. 

On the other hand, if the last sample has been received, the crossbar 46 directs 
the updated coefficient from the adder 44 to the output. (See step 910). Further, the 
1 0 null or pull down device 50 is directed by the cross bar to zero or null the value stored 
in the third memory device as a reset. Further, the AND gate 54 indicates that the 
coefficient value output is a valid value, instead of zero. 

The above steps are repeated for each coefficient until all of the coefficients 
have been updated with the sample. (See step 920 and 930). Further, the process is 
1 5 repeated for each sample, until all samples are received and each coefficient is 
updated. (See step 940). 

Additionally, the first and second latches, 60 and 62, are synchronized with 
the counter so as to output the coefficients and receive a new sample based on the 
clock cycle. Further, the reset device 64 resets the memory. 
20 As detailed above, the apparatus, methods, and computer program products of 

the present invention process a plurality of samples and generate the coefficients of 
the function based on the samples. In some embodiments of the present invention, 
after the plurality of samples have been received, the apparatus, methods, and 
computer program products of the present invention output the generated coefficients. 
25 reset the coefficients, and again take samples of the signal. In some embodiments. 

however, it may be advantageous to generate and output a complete set of coefficients 
as each new sample is received and processed. This is referred to as a Sliding 
Aperture Fourier Transform (SAFT). 

In this embodiment, the apparatus, methods, and computer program products 
30 of the present invention do not reset each of the coefficients to zero after the final 
sample of a plurality of samples has been received and the coefficients have been 
output. Instead, the apparatus, methods, and computer program products of the 
present invention replace the first sample of the previous plurality of samples with the 
next received sample. Using this new sample, the apparatus, methods, and computer 
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program products of the present invention output a next set of coefficients. As such, 
instead of generating a set of coefficients for each 4k batch" of samples, the apparatus, 
methods, and computer program products of the present invention generates a set of 
coefficients each time a new sample is received, thereby providing a new set of 
5 coefficients for each time a new sample is received. 

The present invention provides several apparatus, methods, and computer 
program products for generating a set of coefficients each time a new sample is 
received. In each of these embodiments, the apparatus, methods, and computer 
program products of the present invention replace the contribution of the first sample 
10 of the previous plurality of samples with the contribution of the next sample received 
and then output the new coefficients. For example, in one embodiment, the 
apparatus, methods, and computer program products of the present invention initially 
store each of the samples as they are received and generates a first set of coefficients 
when the last sample of the plurality of samples has been received. Further, when a 
1 5 new sample of the input signal is received, (after the predetermined plurality of 

samples has already been received), the apparatus, methods, and computer program 
products of the present invention apply the mathematical function associated with the 
coefficients to the new sample and generate a term based on the new sample for each 
coefficient. To replace the new sample with the first sample of the plurality of the 
20 samples, the generated term of the new sample is subtracted from the term associated 
with the first sample of the predetermined plurality of samples that was previously 
stored in a memory device. Following this subtraction, the coefficients are updated 
by the difference between the terms based upon the new sample and the first sample 
of the predetermined plurality of samples. 
25 In another embodiment of the present invention, to replace the new sample 

with the first sample of the plurality of samples, the apparatus, method, and computer 
program products of the present invention subtract the term based upon a first sample 
of the predetermined plurality of samples from each of the coefficients and adds the 
term based upon the new sample to each of the coefficients. As such, in one 
30 embodiment, the terms for the new and oldest sample are first subtracted from each 

other and the remainder is added to the coefficients, while in another embodiment, the 
term associated with the oldest sample is subtracted from each coefficient and the 
term associated with the new sample is added to the coefficients. This second 
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embodiment typically experiences less computational drift and is illustrated in Figure 
15. 

Specifically, the coefficient generator 10 of Figure 15 includes all of the 
components of the coefficient generator illustrated and described in Figure 13. 
5 However, the coefficient generator of Figure 1 5 further includes a forth memory 

device 66 in electrical communication with the third memory device 48 for storing the 
terms associated with each sample of a plurality of samples. The coefficient generator 
further includes an adder 68 in electrical communication with the third and forth 
memory devices for subtracting the term associated from the first sample of a 
1 0 previous plurality of samples from the term associated with newly received sample. 

With reference to Figure 16, in operation in this embodiment, similar to 
previous embodiments, for each sample, the receiver receives a sample of the signal 
and inputs the sample to the first memory device 22. (See step 1000). For each 
coefficient, inputs, 18 and 20, are provided to the second memory device representing 
1 5 the sample number and coefficient number, (see step 1010), and based on the inputs, 
the second memory device outputs a token. (See step 1020). Based on the token and 
sample, the first memory device generates a term representing the contribution of the 
sample to the coefficient. (See step 1030). 

If either the sign of the signal is negative or the sign bit of the token is set, the 
20 second AND gate outputs a carry bit to the adder 36. The adder will make the output 
of the first memory device negative. (See steps 1040 and 1050). Likewise, if either 
the signal or the token indicates a zero value, a zero value is output by the first AND 
gate 28. The zero value is output to the first memory device, which disables the first 
memory device. Due to the disablement of the first memory device, the null or pull 
25 down device 34 outputs a zero value representing the value of the coefficient. (See 
steps 1060 and 1070). For the zero case, sign is ignored. The term of the coefficient 
is then output. 

The term is next provided to the adder 44, which also receives the previous 
value of the coefficient from the third memory device 48. The third memory device is 
30 also connected to the second memory device. The token from the second memory 
device addresses the coefficient stored in the third memory device, which, in turn, is 
output to the adder for adding to the term. The term is added to the existing 
coefficient by the adder. (Sec step 1080). 
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The forth memory device is also connected to the second memory device. The 
token from the second memory device addresses the term stored in the forth memory 
device representing the term associated with the first sample of the plurality of 
samples, (i.e.. the oldest sample). The term is provided to the adder 68, where the 
5 term is subtracted from the updated coefficient. (See step 1090). The term associated 
with the new sample is stored in the forth memory device, (see step 1100), the 
updated coefficient is stored in the third memory device, (see step 1110), and also 
output. (See step 1120). The above steps are repeated for each coefficient until all of 
the coefficients have been updated with the sample. (See steps 1130 and 1140). 
1 o As illustrated in some of the embodiments above, the apparatus, methods, and 

computer program products of the present invention may be used in parallel for a 
series of channels for which the present invention generates for each channel 
coefficients of a function representing a signal on the channel. As detailed above, the 
present invention determines the coefficients of the function representative of signal 
1 5 by combining each sample upon receipt with the mathematical function associated 
with the sample and the coefficient. Further, as detailed above, the different 
combinations of the samples and coefficients may be pre-calculated and stored in an 
addressable memory device or may be computed by a gated function with reference to 
a value associated with the token. Typically, the tokens that address the cells of the 
20 memory device are derived from state information obtained from the counter 

indicating the coefficient and the sample. While in the normal operation, the tokens 
and memory device are used to determine the coefficients of a function that is 
representative of a signal, these tokens and memory devices may also be used 
repetitively by adding bits to the counter at appropriate locations and thus service a 
25 multiplicity of channels. In this embodiment, additional coefficient memory cells 
maintain the additional coefficients, and a channel number may be output as a 
convenience to the user. It is still possible employ an electrical signal to determine 
the forward coefficients or to determine the inverse function of the input. 

Further, while in the normal operation, the tokens and memory device are used 
30 to determine the coefficients of a function that is representative of a signal, these 
tokens and memory devices may also be used repetitively by adding bits to the 
counter at appropriate locations and thus service a multiplicity of channels. In this 
embodiment, additional coefficient memory cells maintain the additional coefficients, 
and a channel number may be output as a convenience to the user. By letting 
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consecutive samples be treated as different channels it is possible to thus produce 
interleaved transforms. The interleaved transforms may be sent to a second similar 
process lo produce two-dimensional transforms, for example. 

As detailed above, the apparatus, methods, and computer program products of 
5 the present invention are capable of not only determining the coefficients of a 
function but also the coefficients of an inverse function. This is accomplished in 
many instances by switching the addresses of the tokens, such that the tokens address 
the values representing the inverse function. In instances in which the coefficient 
generator is used with a plurality of channels. The coefficient generator may be 
1 0 advantageously controlled such that for one channel it provides the coefficients of a 
function representative of one signal, while also providing the coefficients of an 
inverse function of another signal for a separate channel. 

As detailed in the various embodiments illustrated above, the apparatus, 
methods, and computer program products of the present invention update each 
1 5 coefficient as each sample is received. Further, in some embodiments, the apparatus, 
methods, and computer program products of the present invention outputs the 
coefficients each time a new sample is received. This is advantageous as it allows 
individual coefficients of interest to be observed and tracked. Individual coefficients 
of interest may be tracked by controlling the coefficient generator to output these 
20 coefficients. This provides a user with a new set of coefficients in real or near real- 
time for observance. 

An additional advantage, is that the coefficients can also be updated with 
different resolutions. Specifically, there may be instances where some of the 
coefficients are of greater interest or there is limited hardware resources such that not 
25 all coefficients can be properly processed and stored. In these instances, the 

coefficient generator can be controlled to only update certain coefficients or to update 
some coefficients with each sample, while coefficients of less importance are updated 

with fewer of the samples. 

In addition to providing apparatus and methods, the present invention also 
30 provides computer program products for determining the coefficients of a function 
representative of an input signal based on a predetermined plurality of samples of the 
input signal. The computer program products have a computer readable storage 
medium having computer readable program code means embodied in the medium. 
The computer readable storage medium may replace the coefficient generator and 
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perform the functions of the coefficient generator through software. Further, 
computer readable storage medium may control the coefficient generator by providing 
the addresses for determining the coefficients. 

The computer-readable program code means includes first computer 
5 instruction means for receiving each of the samples one at a time. Further, the 

computer-readable program code means includes second computer instruction means 
for updating the coefficients of the function based on each sample as the sample is 
received without awaiting receipt of ail samples to thereby decrease the latency of the 
time required to determine the coefficients of the function. In a further embodiment, 
1 0 each coefficient is comprised of at least one term that is at least partially based upon a 
combination of a sample and a mathematical function. In this embodiment, the 
computer-readable program code means further includes third computer instruction 
means for determining a respective term of each coefficient by combining each 
sample upon receipt with the mathematical function associated with the sample and 
1 5 the coefficient. In still another embodiment, the each sample only contributes to one 
term of each coefficient. In this embodiment, the second computer instruction means 
updates each of the coefficients based on each sample upon receipt without requiring 
the sample to thereafter be stored. 

The present invention also provides computer program products for reducing 
20 the number of values that must be stored to represent the possible mathematical terms 
of a function. In this embodiment, the computer program products include a 
computer readable storage medium having computer readable program code means 
embodied in the medium. The computer-readable program code means includes first 
computer instruction means for generating a first list of all possible mathematical 
25 terms of the function. A second computer instruction means systematically compares 
each mathematical term in the list to all other mathematical terms in the list to 
determine which of the mathematical terms are redundant. The computer-readable 
program code also includes third computer instruction means for storing in a second 
list all of the unique mathematical terms of the function, such that there are no 
30 redundant mathematical terms of the function in the second list. 

In one embodiment of the present invention, the function is periodic and 
symmetrical about zero, such that some of the mathematical terms of the function 
have the same magnitude and different signs. In this embodiment, the second 
computer instruction means compares the magnitude of each mathematical term in the 
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list to the magnitude of each of the other mathematical terms in the list to determine 
which of the mathematical terms have the same magnitude. Further, the third 
computer instruction means stores in the second list all of the mathematical terms 
having unique magnitudes. The computer-readable program code means of this 
5 embodiment further includes fourth computer instruction means for creating a token 
associated with each mathematical term, where the token indicates the magnitude 
stored in the second list associated with the mathematical term and the sign associated 
with the mathematical term. ••. — 
In another embodiment, at least one of the mathematical terms has a 
1 0 magnitude of zero. In this embodiment, the computer-readable program code means 
further includes fourth computer instruction means for creating a token associated 
with the mathematical term indicating that the mathematical term is zero such that 
said storing step does not store the mathematical term in the second list. 

In some embodiments, the computer-readable program code means further 
1 5 includes fourth computer instruction means for addressing each of the mathematical 
terms in the second list, such that the mathematical terms may be retrieved. In a 
further, embodiment, the function is representative of a signal and is defined by 
samples of the signal, where a sample of the signal is one of a finite number of 
possible values. In this embodiment, the first computer instruction means generates a 
20 first list of all possible combinations of the possible values of the sample and the 

mathematical terms of the function. Further, the second computer instruction means 
systematically compares each combination in the list to all other combinations in the 
list to determine which of the combinations are redundant, and the third computer 
instruction means stores in a second list all of the unique combinations, such that 
25 there are no redundant combinations in the second list. 

In addition to providing computer program products that generate the 
coefficients of a function and computer program products that reduce the number of 
stored values, the present invention also provides computer program products that 
generate a circuit design or a computer program that determines the coefficients of a 
30 function by updating at least one of the coefficients prior to receipt of the last sample. 
Specifically, as known in the art, there are computer programs that allow for the input 
of specified parameters and output circuit designs or computer software to implement 
the functions defined by the parameters. The present invention provides computer 
program products that receive parameters concerning the functions to be performed 
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by the system and generates either a circuit design or computer program for 
implementing the functions. For example, in one embodiment, the computer program 
product receives all the possible mathematical terms of a function and generates either 
a circuit or computer program that uses the possible mathematical terms to generate 
5 the coefficients of a function with reduced hardware or reduced data storage. 

In this regard, Figures 1-16 are block diagram, flowchart and control flow 
illustrations of methods, systems and program products according to the invention. It 
will be understood that each block or step of the block diagram, flowchart and control 
flow illustrations, and combinations of blocks in the block diagram, flowchart and 
1 0 control flow illustrations, can be implemented by computer program instructions. 
These computer program instructions may be loaded onto a computer or other 
programmable apparatus to produce a machine, such that the instructions which 
execute on the computer or other programmable apparatus create means for 
implementing the functions specified in the block diagram, flowchart or control flow 
1 5 block(s) or step(s). These computer program instructions may also be stored in a 
computer-readable memory that can direct a computer or other programmable 
apparatus to function in a particular manner, such that the instructions stored in the 
computer-readable memory produce an article of manufacture including instruction 
means which implement the function specified in the block diagram, flowchart or 
20 control flow block(s) or step(s). The computer program instructions may also be 
loaded onto a computer or other programmable apparatus to cause a series of 
operational steps to be performed on the computer or other programmable apparatus 
to produce a computer implemented process such that the instructions which execute 
on the computer or other programmable apparatus provide steps for implementing the 
25 functions specified in the block diagram, flowchart or control flow block(s) or step(s). 

Accordingly, blocks or steps of the block diagram, flowchart or control flow 
illustrations support combinations of means for performing the specified functions, 
combinations of steps for performing the specified functions and program instruction 
means for performing the specified functions. It will also be understood that each 
30 block or step of the block diagram, flowchart or control flow illustrations, and 
combinations of blocks or steps in the block diagram, flowchart or control flow 
illustrations, can be implemented by special purpose hardware-based computer 
systems which perform the specified functions or steps, or combinations of special 

purpose hardware and computer instructions. 
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Many modifications and other embodiments of the invention will come to 
mind to one skilled in the art to which this invention pertains having the benefit of the 
teachings presented in the foregoing descriptions and the associated drawings. 
Therefore, it is to be understood that the invention is not to be limited to the specific 
5 embodiments disclosed and that modifications and other embodiments are intended to 
be included within the scope of the appended claims. Although specific terms are 
employed herein, they are used in a generic and descriptive sense only and not for 
purposes of limitation. 
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Appendix 1 

Example of a program evaluating a Standard Fourier Series. 



SI := I S2:=2 S3 :=- I S4:=3 S5:=-4 S6:=l S7:=0 S8:=2 
Evaluate the AO value. 

AOj^Sl A0^:=S2 AO. :=S3 A0 4 :=S4 

AO. :=S5 A0 6 :=S6 A0 ? :=S7 A0 g :=S8 

AO : = AO , + AO, +■ A0 3 + A0 4 + A0 $ -I- A0 fi +- A0 ? + A0 g AO = 4 

Evaluate A1 



:Sl«,^LLlj Al 2 :=S2-cosp-ii) Al 3 :=S3<«(=2L!2j Al 4 :=S4. C os (l!L 



•1-4 

Al, :=Sl-cos|~ " ' "I Al, :=S2cosl— — j Al 3 :=53cos| j Ai 4 :=S4 cos ( 

{ \ 8 / \ 8 

A ,.:=S5-cos(mi) Al,:=S6.cos[l!L±^] Al, := S7-cosfe?±Z'! A. , :- S8cos 

8 / 6 V 8 / \ 8 J \ 8 ; 

Al :=Al.f A1,-t-Al,+ Al d +AL+Al VA1 +A1 Al =3.243 



Evaluate A2 



...JilA A2 2 :=S2.cos(l!L^ A2 3 :=S3.cos(l!Lii) A2 4 :=S4 W 4f±fj 

A2 5 :=S5.cos(l^£j A2 6 := S6-COS ^ := S7 . cos A2, -SS-cos/l^ 

A2 -A2J-*- A2,+- A2 3 -h A2 4 + A2 5 + A2 6 -h A2 ? + A2 g A2 = 2 



Evaluate A3 

A3 i :=Sl.os|l^ A3 2 :=S2-cos^±£j A3 3 := S3xos A V =S4.os^' 

A3.:=S5.cosfl!Li£\ A3, := S6-cos f*l2*) A3 ? := S7-cos \*l±t[ A3 g := S8.cs 

I 8 / 6 \ 8 / 7 • 8 .' 8 i 8 

\ / \ / \ / 

A3 := A3 , + A3, + A3 3 + A3 4 + A3 5 +- A3 6 A3 ? -t- A3 g A3 = - 5.243 



Evaluate A4 

/' \ 

A4 :=S.cos ^L±i\ A4,:=S2.cos(ll±£l A4, := S3cos (22*2) A4„ := S4-COS [l!L±i 

> 8 y ■ > 8 " \ 8 / \ 8 . 

A4.:=S5.cosfll±£\ A4 := 56-cos [2i±^ A4, :« 57-cos f*i±Z j A4 •= 58-cos felli 
9 ' 8 ■' 6 I 8 / 7 » 8 / 8 8 

\ ' \ / \ 

A4 :=A4, + A4,-i- A4 3 -t-A4 4 + A4 5 + A4 6 + A4 ? + A4 g A4 = 12 
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Evaluate B1 



Bl. :=Sl-sin( 2 ! 
' \ 8 / 



. BU:=S2-sin(llii) Bl, := S3 sin(l^j BI 4 :=S4sin 



\ 



Bl. :=S5-sin 



( 2-n-N ; 
\ 8 / 



{^) B, :=S6.sin(^i B» 7 :=S7.i„(^ „.. :.**»( 

. « ; * \ 8 / \ 8 / 



/2-n-1-8\ 



Bl-BI. + BU+B^+B^+Blj+B^+Bl^Bl^ 



Bl =3.828 



Evaluate B2 

1 \ 8 / \ 8 / \ 8 / 



\ 8 / 



B2_ :=S5*sin! 



B V =S^(^| BV-,,^) ■V"*!^) 



1 2-n -2-5 \ 
\ 8 / 



B2 := B2, + B2, + B^ + B2^ + B2, + B2 (j + B2 ? + B2 8 
Evaluate B3 

:» B3, :=S3sin 



B2=-2 



B3, ^Sl-sinf 2 '",' 3 ' 1 ) B3,:=S2-sin v 



B3. :=S5 sin 



fi n -3-5 



I 8 



■j —3 



. , B3, :=S6 sin, 

\ 8 / 6 \ 8 



\ 8 



\ 8 / 



i j2^3 J 6\ B3 . = S7 . lin /2l±Z\ B3L:=SS*inf 2 *- 3 ^ 



B3 : = B3, + B3, + B3 3 -H B3, + B3 S + B3 6 + B3 ? + B3 g B3 = 1 .828 

Evaluate B4. All terms are zero for any even number of samples. 



B4, :=Sl-sin(^li| B4 2 := S2 sin(_— ) 



/2-n-4-3\ - /2-n-4-4\ 

B4 3 := S3 -sin (^pH B4 4 := S4 s,n j 



B4. :=S5 sin! 2 "' 4 5 | B4. :=S6-sin! 

\ 8 / 6 \ 8 



B4, :=S7 sin 



ll-n -4-7 \ 



B4 C :=S8-sin : 



<2-7i -4-8 



B4 : = B4 ( B4 2 + B4 3 + B4 4 + B4 S + B4 & -h B4 ? + B4 g 
Adjusting the classical coefficients to the forms used: 



B4 =-7.348- 10" 



15 



AO 

DC value = AO/N ADC := — 

8 



A4 



Truncation Value: Divide A4 by 2. A4T := — 
Which gives the Fourier Transform: 

ADC = 0.5 Al = 3.243 A2 = 2 A3 =-5.243 A4T = 6 

Bl =3.828 B2 = -2 B3= 1.828 



FT := 



Al A2 A3 A4T 
Bl B2 B3 ADC 



FT 



3.243 2 -5.243 6 
3.828 -2 1.828 0.5 
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Appendix 2 

Example of a program evaluating a Fast Fourier Series according to one 
embodiment of the present invention. 

All computations are done on a sample-by-sample basis with one register dedicated 
to each coefficient and being updated with each successive sample. 

Sl := , On arrival of the first sample all coefficients are processed with respect to it. 

A01 :=S1 

A n:=S..cos(l^ii) A2,:=S.-cos^l) A3 , := S. -cos (l2±i) A4 . = S , -cos fcl±l 

. 12-n 4 \ 



/ \ / \ / 

B , | :=Sl sin/l!L±i] B21 : = S 1 sin fl^i | B31 := SI -sin(ll±l j B41 :=Sl.sin(: 

\ g ; \ 8 / \ 8 / \ b 



52 : = 2 On arrival of the second sample all coefficients are updated with it. 

A02 :=S2 

A,^S2.co s (k±?) Ao^^j AMrMJc-j^J A42 , S2-C.S j 
BI 2-, S 2.J^j B22:=S2,in^j B32:=S2«.^| M2 :=S2,in^Llij 

A0 p :=A01 + A02 

Al p := All + A12 A2 12 :=A21 + A22 A3 J2 := A3I + A32 A4, 2 := A41 + A42 

Bl p := Bl 1+ B12 B2 I2 :=B2H- B22 B3 ]2 :=B31-h B32 B4 p :=B41 + B42 

53 ! On arrival of the third sample all coefficients are updated with it. 

A03:=S3 

A1 3:=S3.cos/HLii; A23:=S3.cos(l?^2) A33 ^-cosfe-M j A43 := S3-COS 



/ 



2-Ti -2-3\ „,.,-«., - : J2 " -3-3 \ R^:=j53.rin(- n " 4 ' 3 . 



B13:=S3-sin( 2 - 7113 ) B23:=S3. S in(i^ j B33 := S3-sin [z^- j B43:=S3sin; 



8 / \ 8 1 \ 8 / \ 8 



\ 
\ 



A0 J3 -=A0 I2 + A03 



A1 13 :=A1 |2 +A13 A2 u :=A2 |2 -hA23 A3 |3 := A3 n + A33 A4 |3 := A4 |2 + A43 

BI |3 :=BI |2 -eBI3 B2 |3 := B2, 2 + B23 B3 J3 := B3 |2 + B33 B4 |3 :=B4, 2 + B43 
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S4:=3 
A04 :=S4 



On arrival of the fourth sample all coefficients are updated with it. 
■ 2*-M \ a24 : ^ S4 . c J^±1\ A34 :=S4^os(l^±lj A44 :=S4.cos 



/2-7T *4 4\ 



A14:=S4-cos ZJ^\ A24-S4COS — — , a^-^™> : — — ~~ • - ; 
8 / \ 8 / ° 

•±!L±1\ B24:=S4.s i nfl!lii' B34 :=S4-sin [^J±] B44:=S4-sinf±^ I 



B14:=S4sin 

8 



A0, 4 * = A0 |3 + A04 



A1 |4 :=A1 13+ AI4 A2 14 :=A2 )3 ^A24 A3 , 4 := A3 , 3 + A34 . A4 )4 := A4, 3+ - A44 

B1 14 :=B1 13 + B14 B2, 4 :=B2 I3 + B24 B3 |4 :=B3 |3+ B34 B4 |4 :=B4, 3 + B44 

S5 : =-4 On arrival of the fifth sample all coefficients are updated with it. 

AOS :=S5 

A1 ,,S.«.(i2±3 «5:=S^ S (^i) *»~SS~<™±) M»~~^fi 



B15:=S5-sin! 



8 / V « 

,. / 2-n -1 -5 \ m< ._ /2^5\ ms :b S5 . sin /±1±£^ B45 := SS sin {^L±l 



8 



j B25:=S5.sin^^j B35 :=S5sin'p-^j B45 := S5 s.n (_ 



A0, 5 :=A0 M + A05 



A , i5 : =A1]4 + A15 A2, 5 :=A2 14+ A25 A3, 5 := A3, 4 + A35 A4, s :« M„+ A45 

B1 15 :=B1 |4+ B15 B2, 5 :=B2 14 -HB25 B3, 5 :=B3 )4 + B35 B4, 5 := B4, 4 +- B45 
S6 := 1 On arrival of the sixth sample all coefficients are updated with it. 
A06 := S6 

/ > /-> i /l\ /->-it -Vfi\ f 2-71-4 -6 '• 

A16:= S6-cos;^) A26 : = S6.cos[^| A36:=S6-cos-^ / A46 :=S6cos ^ - ; 

B , 6 := S6-sin : HLl±) B26 : = S6-sin B36 := S6-sin '^2±) B46 := S6-sin J 



A0 |6 :=A0 |5 +A06 



A , 16 :=A1, 5+ AI6 A2 lt( :=A2 15 -HA26 A3, 6 := A3, 5+ A36 A4, 6 := A4, 5+ - A46 



Bl 1(l :=Bl,. + B16 B2 |( . : =B2, 5+ B26 B3, 6 := B3, 5 -H B36 B4, 6 :« B4, s + B46 
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57 := o On arrival of the seventh sample all coefficients are updated with it. 

A07:=S7 

AI 7:=S7«,(1^LZ) A27:=S7.cos(U^Z) A37 := S7-cos (^) A47 :=S7.cos (UL±Z j 

B1 7:=S7.sin;i!L±zi B27:=S7*n[UL±Z) B37 :--Sl,J^) B47:=S7. S inf±=-±Z j 

\ 8 / \ 8 / \ 8 / v 8 

AO,,, :=A0.,+ A07 

Al )? := Al l6 + A17 A2 1? := A2, 6 + A27 A3 |? := A3 J6 + A37 A4 |? := A4, 6 + A47 

B! J7 :=B1 |6 + B17 B2, ? :=B2 |6 + B27 B3, ? :=B3 |6 + B37 B4, ? :=B4, 6 + B47 

58 := 2 On arrival of the eighth sample all coefficients become complete in a single update. 
The subscript "F" is used rather than 18 to designate final coefficients. 



A08 := S8 



A48 :=S8xosf!^±£! 

< 8 ; 



A18 :=S8«o,[±2L±!) AM^SB^fiiii) A38 := S8-cos fl^!) 

\ 8 / \ 8 / \ 8 / 

B , 8 := S8-sin (liLii) B28 := S8sin (*2L?*) B38 := S8sin |*ZL!i) B48 := S8-sin [i^Lt!j 

F:=18 A0 p :=A0 I7 + A08 

A1 F :=A1 17 + A18 A2 F :=A2, 7 +A28 A3 f := A3,, + A38 A4 p := A4, ? + A48 

Bl p :=Bl 17+ B18 B2 F :=B2 n + B28 B3 p :=B3, 7 -t- B38 B4 p := B4 )? + B48 

Adjusting the classical coefficients to the forms used: 

AO 

DC value = AO/N ADC := — - 

8 

A4 

Truncation Value: Divide A4 by 2. A4T := 

B4F = 0 (Identity for any even number of samples.) 
The resulting Fast Fourier Transform is thus evaluated: 

ADC = 0.5 Al p = 3.243 A2 p = 2 A3 p =-5.243 A4T=6 

Bl F = 3.828 B2 F =-2 B3 p = 1 .828 

An array is designated for the transform values: 
|"A1 F A2 p A3 p A4T 

FT:= 

lBl p B2j. B3 p ADC 

The values are displayed: 
[3.243 2 -5.243 6 ' 

48 



FT = . 

1 3.828 -2 1.828 0.5 
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The complete set of incremental values are listed below: 

A01=t All =0.707 A2I=0 A3 1 =-0.707 A41=-l 

Bl I =0.707 B21 = 1 B3I =0.707 B4I=0 



A02 = 2 A12 

BI2-2 



A06 = 1 A16 = 0 



A07 = 0 A17 = 0 
B17 = 0 



A22=-2 A3 2 =0 A42 = 2 

B22 = 0 B32 = -2 B42 = 0 



A03=-l A 13 = 0.707 A23=0 A33 =-0.707 A43 = 1 

B13 = -0.707 B23=l B33 = -0.707 B43 = 0 

A04 = 3 AI4=-3 A24 = 3 A34=-3 A44 = 3 

B14 = 0 B24 = 0 B34= 1.M0 15 B44 = - 1 .4710" 15 

A05 = - 4 A 1 5 = 2.828 A25 = - 1 -225- 1 0" 1 5 A35 = - 2.828 A45 = 4 

B15 = 2.828 B25=-4 B35= 2.828 B45 =-2.44910" 15 



A26=-l A36 = 0 A46=l 



B16 = -l B26 = 0 B36=l B46 = 0 



A27 = 0 A37 = 0 A47 = 0 

B27-0 B37 = 0 B47 = 0 



A08 = 2 A18 = 2 A28=2 A38 = 2 A48=2 

B18 = 0 



B 28 = 0 B38 = -l.47-10" 15 B48 =- 1.95910" 15 
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THAT WHICH IS CLAIMED: 

1 . An apparatus for determining the coefficients of a function representative 
of an input signal based on a predetermined plurality of samples of the input signal, 
wherein said apparatus comprises a coefficient generator which updates at least one of 

5 the coefficients prior to receipt of the last sample of the plurality of samples to 

thereby decrease the latency of the time required to determine the coefficients of the 
function. 

2. An apparatus according to Claim 1, wherein said coefficient generator 
receives each of the samples one at a time and updates the coefficients of the function 

10 based on each sample as the sample is received without awaiting receipt of all 
samples to thereby decrease the latency of the time required to determine the 
coefficients of the function. 

3. An apparatus according to Claim 2, wherein each coefficient is comprised 
of at least one term that is at least partially based upon a combination of a sample and 

1 5 a mathematical function, wherein said coefficient generator determines a respective 
term of each coefficient by combining each sample upon receipt with the 
mathematical function associated with the sample and the coefficient, and wherein, 
for each coefficient, said coefficient generator updates the coefficient by adding the 
respective term to a previous value of the coefficient. 

20 4. An apparatus according to Claim 3, wherein each sample only contributes 

to one term of each coefficient, and wherein said coefficient generator updates each of 
the coefficients based on each sample upon receipt without requiring the sample to 
thereafter be stored. 

5. An apparatus according to Claim 3, wherein said coefficient generator 

25 updates each of the coefficients with each of the plurality of samples as each sample 
is received, and wherein as each coefficient is updated with the last of the plurality of 
samples, said coefficient generator outputs the coefficient. 

6. An apparatus according to Claim 3, wherein said coefficient generator 
simultaneously updates each of the coefficients based on each of the plurality of 

30 samples as each sample is received, and wherein when the coefficients are updated 
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based on the last of the plurality of samples, said coefficient generator outputs the 
coefficients. 

7. An apparatus according to Claim 3, wherein said coefficient generator 
includes a memory device for storing a value representing the mathematical function 
5 associated with each sample and coefficient, and wherein for each sample and 

coefficient, said coefficient generator accesses said memory device and multiplies the 
sample by the value representing the mathematical function associated with the 
sample and coefficient to thereby define a term, and thereafter updates the coefficient 
by adding the term to the previous value of the coefficient. 

10 8. An apparatus according to Claim 7, wherein said memory device includes 

an array having a plurality of cells, wherein each cell of the array stores a value 
representing the mathematical function associated with a respective sample and 
coefficient, wherein each cell of said array has a unique address, which is designated 
by the respective coefficient and sample, and wherein, for each sample and 

1 5 coefficient, said coefficient generator accesses the cell of said memory device using 
the address associated with the sample and coefficient, multiplies the sample by the 
stored value to thereby define a term, and thereafter updates the coefficient by adding 
the term to the previous value of the coefficient. 

9. An apparatus according to Claim 3, wherein each sample of the signal has a 
20 value that is one of a finite number of possible values, wherein said coefficient 

generator further includes a first memory device having an array of cells with each 
cell associated with a respective sample and coefficient, wherein each cell contains a 
pre-calculated value corresponding to the combination of one of the finite number of 
possible values of the sample and the mathematical function associated with the 
25 respective coefficient and sample, and wherein each cell is represented by a token 
address. 

1 0. An apparatus according to Claim 9, wherein said coefficient generator 
further comprises a second memory device having an array of cells for storing tokens 
that each represent a respective coefficient and sample, and wherein for each sample 
30 said coefficient generator accesses said second memory device and for each 

coefficient retrieves the token associated with the coefficient and the sample and 
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supplies the token to said first memory device, and thereafter retrieves the pre- 
calculated value stored in the cell of said first memory device that has an address 
comprised of the token and the value of the sample, and wherein said coefficient 
generator updates the coefficient by adding the pre-calculated value from said first 
5 memory device to the previous value of the coefficient. 

1 1 . An apparatus according to Claim 9 further comprising at least one gate in 
electrical communication with said coefficient generator for addressing the cells of 
said first memory device, wherein for each sample said gate outputs the token 
associated with the coefficient and the sample to said first memory device, and 
1 0 wherein said coefficient generator retrieves the pre-calculated value stored in the cell 
of said first memory device that has an address comprised of the token and the value 
of the sample, and wherein said coefficient generator updates the coefficient by- 
adding the pre-calculated value from said first memory device to the previous value of 
the coefficient. 

15 1 2. An apparatus according to Claim 9 further comprising a counter in 

electrical communication with said coefficient generator for addressing the cells of 
the said first memory device, wherein for each sample said counter outputs the token 
associated with the coefficient and the sample to said first memory device, and 
wherein said coefficient generator retrieves the pre-calculated value stored in the cell 

20 of said first memory device that has an address comprised of the token and the value 
of the sample, and wherein said coefficient generator updates the coefficient by 
adding the pre-calculated value from said first memory device to the previous value of 
the coefficient. 

13. An apparatus according to Claim 9, wherein each token also indicates if 
25 the value of the mathematical function associated with the respective sample and 
coefficient is zero, wherein said coefficient generator further includes a null device, 
and wherein if the token indicates that the value of the mathematical function is zero 
said coefficient generator updates the coefficient by adding a zero from said null 
device to the previous value of the coefficient. 

30 1 4. An apparatus according to Claim 9. wherein each token also indicates if 

the sign of the mathematical function associated with the respective sample and 
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coefficient is positive or negative, wherein said first memory device contains only 
pre-calculated values corresponding to the combination of a respective sample and the 
magnitude of a respective mathematical function without accounting for the sign of 
the mathematical function, thereby reducing the number of pre-calculated values that 
5 are stored by said first memory device. 

15. An apparatus according to Claim 14, wherein said coefficient generator 
further includes an adder in electrical communication with said first memory device, 
and wherein if said token indicates that the sign of the mathematical function is 
negative, said first memory device outputs the magnitude of the mathematical 

1 0 function and said adder receives the output and generates a negative of the 
mathematical function. 

16. An apparatus according to Claim 1 1 , wherein each token represents a 
respective coefficient and sample, wherein said coefficient generator further includes 
a selector in electrical communication with said first memory device and said gates, 

15 wherein to generate coefficients representing an inverse function of the signal, said 
selector switches the output of said gate such that the token generated by said gate 
addresses a cell in said first memory device containing a pre-calculated value 
representing an inverse mathematical function associated with a respective sample 
and coefficient, and wherein said coefficient generator updates the coefficient by 

20 adding the pre-calculated value from said first memory device to the previous value of 
the coefficient. 

17. An apparatus according to Claim 16. wherein said coefficient generator 
receives samples one at a time from a plurality of signals each present on a separate 
channel, wherein said coefficient generator receives each of the samples one at a time 

25 for each of the signals and based on the tokens from said gate updates the coefficients 
of the function associated with each sample based on each sample associated with the 
signal as the sample is received, wherein said selector switches the output of said gate 
for the samples received from at least on of the channels, such that said coefficient 
generator generates coefficients representing an inverse function of the signal for at 

30 least one channel. 
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1 8. An apparatus according to Claim 3. wherein said coefficient generator 
further comprises a memory device, and wherein said coefficient generator further 
stores each of the samples as they are received in said memory device. 

1 9. An apparatus according to Claim 1 8, wherein after said coefficient 

5 generator has received and processed the predetermined plurality of samples, said 
coefficient generator outputs the coefficients, and wherein when a new sample of the 
input signal is received after the predetermined plurality of samples has already been 
received, said coefficient generator subtracts the term based upon a first sample of the 
predetermined plurality of samples that was previously stored in said memory device 

1 0 from the term based upon the new sample, and wherein said coefficient generator 
updates the coefficients by the difference between the terms based upon the new 
sample and the first sample of the predetermined plurality of samples. 

20. An apparatus according to Claim 1 8, wherein after said coefficient 
generator has received and processed the predetermined plurality of samples, said 

1 5 coefficient generator outputs the coefficients, and wherein when a new sample of the 
input signal is received after the predetermined plurality of samples have already been 
received, said coefficient generator subtracts the term based upon a first sample of the 
predetermined plurality of samples that was previously stored in said memory device 
from each of the coefficients, and wherein said coefficient generator adds the term 

20 based upon the new sample to each of the coefficients. 

2 1 . An apparatus according to Claim 1 , wherein the function of the input 
signal is a Fourier transform, and wherein the mathematical function associated with 
each coefficient and signal is a trigonometric function. 

22. An apparatus according to Claim 2, wherein there is at one preselected 
25 coefficient of interest, and wherein said coefficient generator receives each of the 

samples one at a time and updates the preselected coefficient of the function based on 
each sample as the sample is received, such that the preselected coefficient may be 
evaluated independent of the other coefficients. 

23. An apparatus according to Claim 22, wherein said coefficient generator 
30 outputs the preselected coefficient each time the coefficient is updated. 
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24. An apparatus according to Claim 22. wherein there are at least one first 
and second preselected coefficients of interest, and wherein said coefficient generator 
updates the first preselected coefficient of interest with a different number of samples 
than the second preselected coefficient of interest, such that the resolution of each 

5 preselected coefficient is different. 

25. An apparatus according to Claim 2, wherein said coefficient generator 
receives samples one at a time from a plurality of signals each present on a separate 
channel, wherein said coefficient generator receives each of the samples one at a time 
for each of the signals and updates the coefficients of the function associated with 

1 0 each sample based on each sample associated with the signal as the sample is 
received. 

26. An apparatus according to Claim 25, wherein said coefficient generator 
simultaneously receives samples one at a time from a plurality of signals each present 
on a separate channel, wherein said coefficient generator receives each of the samples 

1 5 one at a time for each of the signals and simultaneously updates the coefficients of the 
function associated with each sample based on each sample associated with the signal 
as the sample is received. 

27. A method for determining the coefficients of a function representative of 
an input signal based on a predetermined plurality of samples of the input signal, 

20 wherein said method comprises the steps of: 
receiving samples of the signal: and 

updating at least one of the coefficients prior to receipt of the last sample of 
the plurality samples to thereby decrease the latency of the time required to determine 
the coefficients of the function. 

25 28. A method according to Claim 27, wherein said receiving step comprises 

receiving each of the samples one at a time, and wherein said updating step comprises 
updating the coefficients of the function based on each sample as the sample is 
received without awaiting receipt of all samples to thereby decrease the latency of the 
time required to determine the coefficients of the function. 

30 29. A method according to Claim 28, wherein each coefficient is comprised 

of at least one term that is at least partially based upon a combination of a sample and 
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a mathematical function, wherein said method further comprises the step of 
determining a respective term of each coefficient by combining each sample upon 
receipt with the mathematical function associated with the sample and the coefficient, 
and wherein, for each coefficient, said updating step updates the coefficient by adding 
5 the respective term to a previous value of the coefficient. 

30. A method according to Claim 29, wherein each sample only contributes to 
one term of each coefficient, and wherein said updating step updates each of the 
coefficients based on each sample upon receipt without requiring the sample to 
thereafter be stored. 

! 0 31. A method according to Claim 29, wherein said updating step updates each 

of the coefficients with each of the plurality of samples as each sample is received, 
and wherein as each coefficient is updated with the last of the plurality of samples, 
said updating step outputs the coefficient. 

32. A method according to Claim 29, wherein said updating step 

1 5 simultaneously updates each of the coefficients based on each of the plurality of 
samples as each sample is received, and wherein when the coefficients are updated 
based on the last of the plurality of samples, said updating step outputs the 
coefficients. 

33. A method according to Claim 29 further comprising the step of initially 
20 storing a value representing the mathematical function associated with each sample 

and coefficient in a memory device, and wherein for each sample and coefficient, said 
determining step accesses the memory device and multiplies the sample by the value 
representing the mathematical function associated with the sample and coefficient to 
thereby define a term, and wherein said updating step updates the coefficient by 
25 adding the term to the previous value of the coefficient. 

34. A method according to Claim 33, wherein the memory device includes an 
array having a plurality of cells, wherein said storing step comprises storing in each 
cell of the array a value representing the mathematical function associated with a 
respective sample and coefficient, wherein each cell of the array has a unique address, 

30 which is designated by the respective coefficient and sample, and wherein, for each 
sample and coefficient, said determining step accesses the cell of the memory device 
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using the address associated with the sample and coefficient, multiplies the sample by 
the stored value to thereby define a term, and thereafter said updating step updates the 
coefficient by adding the term to the previous value of the coefficient. 

35. A method according to Claim 29, wherein each sample of the signal has a 
5 value that is one of a finite number of possible values, wherein said method further 

comprises the step of storing in a first memory device having an array of cells a pre- 
calculated value corresponding to the combination of one of the finite number of 
possible values of the sample and the mathematical function associated with each 
coefficient and sample such that each cell is associated with a respective sample, 
10 coefficient, and finite value of the sample, and wherein each sell is represented by a 
token address. 

36. A method according to Claim 35, wherein said method further comprises 
the step of storing in a second memory device having an array of cells tokens that 
each represent a respective coefficient and sample, wherein for each sample said 

1 5 determining step accesses the second memory device and for each coefficient 

retrieves the token associated with the coefficient and the sample and supplies the 
token to the first memory device, and thereafter retrieves the pre-calculated value 
stored in the cell of the first memory device that has an address comprised of the 
token and the value of the sample, and wherein said updating step updates the 

20 coefficient by adding the pre-calculated value from the first memory device to the 
previous value of the coefficient. 

37. A method according to Claim 35, further comprising the step of 
addressing the cells of the first memory device, wherein for each sample said 
addressing step outputs the token associated with the coefficient and the sample to the 

25 first memory device, and wherein said determining step retrieves the pre-calculated 
value stored in the cell of the first memory device that has an address comprised of 
the token and the value of the sample, and wherein said updating step updates the 
coefficient by adding the pre-calculated value from the first memory device to the 
previous value of the coefficient. 

30 38. A method according to Claim 35. wherein each token also indicates if the 

value of the mathematical function associated with the respective sample and 
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coefficient is zero, and wherein said updating step updates the coefficient by adding a 
zero to the previous value of the coefficient if the token indicated that the value of the 
mathematical function is zero. 

39. A method according to Claim 35, wherein each token also indicates if the 
5 sign of the mathematical function associated with the respective sample and 

coefficient is positive or negative, wherein said storing in the first memory device step 
comprises storing only pre-calculated values corresponding to the combination of a 
respective sample and the magnitude of a respective mathematical function without 
accounting for the sign of the mathematical function, thereby reducing the number of 
10 pre-calculated values that are stored by the first memory device. 

40. A method according to Claim 35. and wherein each token represents a 
respective coefficient and sample, wherein said method further comprises the step of 
selecting the tokens, wherein to generate coefficients representing an inverse function 
of the signal, said selecting step switches the contents of the token such that the token 

1 5 addresses a cell in the first memory device containing a pre-calculated value 

representing an inverse mathematical function associated with a respective sample 
and coefficient, and wherein said updating step updates the coefficient by adding the 
pre-calculated value from the first memory device to the previous value of the 
coefficient. 

20 4 1 . A method according to Claim 40, wherein said receiving step receives 

samples one at a time from a plurality of signals each present on a separate channel, 
wherein said determining step receives each of the samples one at a time for each of 
the signals and based on the tokens from said selecting step updates the coefficients of 
the function associated with each sample based on each sample associated with the 

25 signal as the sample is received, wherein said selecting step switches the tokens for 
the samples received from at least on of the channels, such that said determining step 
generates coefficients representing an inverse function of the signal for at least one 
channel. 

42. A method according to Claim 29 further comprising the step of storing 
30 each of the samples as they are received in a memory device. 
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43. A method according to Claim 42. wherein after said receiving step has 
received and said updating step has processed the predetermined plurality of samples, 
said updating step outputs the coefficients, and wherein when a new sample of the 
input signal is received by said receiving step after the predetermined plurality of 

5 samples has already been received, said method further comprises the step of 
subtracting the term based upon a first sample of the predetermined plurality of 
samples that was previously stored in said storing step from the term based upon the 
new sample, and wherein said updating step updates the coefficients by the difference 
between the terms based upon the new sample and the first sample of the 
1 0 predetermined plurality of samples. 

44. A method according to Claim 42, wherein after said receiving step has 
received and said updating step has processed the predetermined plurality of samples, 
said updating step outputs the coefficients, and wherein when a new sample of the 
input signal is received by said receiving step after the predetermined plurality of 

1 5 samples have already been received, said method further comprises the step of 
subtracting the term based upon a first sample of the predetermined plurality of 
samples that was previously stored in said storing step from each of the coefficients, 
and wherein said updating step adds the term based upon the new sample to each of 
the coefficients. 

20 45. A method according to Claim 27, wherein the function of the input signal 

is a Fourier transform, and wherein the mathematical function associated with each 
coefficient and signal is a trigonometric function. 

46. A method according to Claim 28, wherein there is at one preselected 
coefficient of interest, and wherein said receiving step receives each of the samples 

25 one at a time and said updating step updates the preselected coefficient of the function 
based on each sample as the sample is received, such that the preselected coefficient 
may be evaluated independent of the other coefficients. 

47. A method according to Claim 46. wherein said updating step outputs the 
preselected coefficient each time the coefficient is updated. 

30 48. A method according to Claim 47, wherein there are at least one first and 

second preselected coefficients of interest, and wherein said updating step updates the 
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First preselected coefficient of interest with a different number of samples than the 
second preselected coefficient of interest, such that the resolution of each preselected 
coefficient is different. 

49. A method according to Claim 28, wherein said receiving step receives 

5 samples one at a time from a plurality of signals each present on a separate channel, 
wherein said updating step receives each of the samples one at a time for each of the 
signals and updates the coefficients of the function associated with each sample based 
on each sample associated with the signal as the sample is received. 

50. A method according to Claim 49, wherein said receiving step 

1 0 simultaneously receives samples one at a time from a plurality of signals each present 
on a separate channel, wherein said updating step receives each of the samples one at 
a time for each of the signals and simultaneously updates the coefficients of the 
function associated with each sample based on each sample associated with the signal 
as the sample is received. 

1 5 5 1 . An apparatus for determining the coefficients of a function for a given 

input signal based on a sample of the input signal, wherein each coefficient is 
comprised of at least one term that is at least partially based upon a combination of 
the sample and a mathematical function, wherein said apparatus comprises: 

a first memory device for storing a value representing the mathematical 
20 function associated with the sample and each coefficient; and 

a coefficient generator in electrical communication with said memory device, 
wherein said coefficient generator receives the sample of the input signal and for each 
coefficient accesses said first memory device and multiplies the sample by the value 
representing the mathematical function associated with the sample and coefficient to 
25 thereby define a term, and thereafter updates the coefficient by adding the term to the 
previous value of the coefficient. 

52. An apparatus according to Claim 5 1 , wherein said first memory device 
includes an array having a plurality of cells, wherein each cell of the array stores a 
value representing the mathematical function associated with the respective sample 
30 and each coefficient, wherein each cell of said array has a unique address, which is 
designated by the respective coefficient and sample, and wherein, for the sample and 
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each coefficient, said coefficient generator accesses the cell of said first memory 
device using the address associated with the sample and coefficient, multiplies the 
sample by the stored value to thereby define a term, and thereafter updates the 
coefficient by adding the term to the previous value of the coefficient. 

5 53. An apparatus according to Claim 51, wherein the sample of the input 

signal has a value that is one of a finite number of possible values, wherein said first 
memory device has an array of cells with each cell associated with the sample and 
each coefficient, wherein each cell contains a pre-calculated value corresponding to 
the combination of one of the finite number of possible values of the sample and the 

1 0 mathematical function associated with the respective coefficient, wherein said 

coefficient generator further comprises a second memory device having an array of 
cells for storing tokens that each represent a respective coefficient and the sample, and 
wherein for each sample said coefficient generator accesses said second memory 
device and retrieves the token associated with the coefficient and the sample and 

1 5 supplies the token to said first memory device, and thereafter retrieves the pre- 
calculated value stored in the cell of said first memory device that has an address 
comprised of the token and the value of the sample, and wherein said coefficient 
generator updates the coefficient by adding the pre-calculated value from said first 
memory device to the previous value of the coefficient. 

20 54. An apparatus according to Claim 53, wherein each token also indicates if 

the value of the mathematical function associated with the sample and respective 
coefficient is zero, and wherein said coefficient generator updates the coefficient by 
adding a zero to the previous value of the coefficient. 

55. An apparatus according to Claim 53, wherein each token also indicates if 
25 the sign of the mathematical function associated with the respective sample and 
coefficient is positive or negative, wherein said first memory device contains only 
pre-calculated values corresponding to the combination of a respective sample and the 
magnitude of a respective mathematical function without accounting for the sign of 
the mathematical function, thereby reducing the number of pre-calculated values that 
30 are stored by said first memory device. 
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56. A method for determining the coefficients of a function for a given input 
signal based on a sample of the input signal, wherein each coefficient is comprised of 
at least one term that is at least partially based upon a combination of the sample and 
a mathematical function, wherein said method comprises: 

5 storing a value representing the mathematical function associated with the 

sample and each coefficient in a first memory device; 
receiving the sample of the input signal; 

determining a respective term of each coefficient by accessing the first 
memory device, multiplying the sample by the value representing the 
10 mathematical function associated with the sample and coefficient to thereby define a 
term; and 

updating each coefficient by adding the respective term to the previous value 
of the coefficient. 

57. A method according to Claim 56, wherein the first memory device 

1 5 includes an array having a plurality of cells, wherein said storing step stores a value 
representing the mathematical function associated with the sample and a respective 
coefficient in each cell of the array, wherein each cell of the array has a unique 
address, which is designated by the respective coefficient and sample, and wherein, 
for the sample and each coefficient, said determining step accesses the cell of the first 

20 memory device using the address associated with the sample and coefficient and 

multiplies the sample by the stored value to thereby define a term, and thereafter said 
updating step updates the coefficient by adding the term to the previous value of the 
coefficient. 

58. A method according to Claim 56, wherein the sample of the input signal 
25 has a value that is one of a finite number of possible values, wherein said storing step 

comprises storing in a first memory device having an array of cells a pre-calculated 
value corresponding to the combination of one of the finite number of possible values 
of the sample and the mathematical function associated with each coefficient such that 
each cell contains a pre-calculated value corresponding to the combination of one of 
30 the finite number of possible values of the sample and the mathematical function 
associated with the respective coefficient, wherein said method further comprises 
storing tokens that each represent a respective coefficient and the sample in a second 
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memory device having an array of cells, and wherein for each sample said 
determining step accesses the second memory device and retrieves the token 
associated with the coefficient and the sample and supplies the token to the first 
memory device, and thereafter retrieves the pre-calculated value stored in the cell of 
5 the first memory device that has an address comprised of the token and the value of 
the sample, and wherein said updating step updates the coefficient by adding the pre- 
calculated value from the first memory device to the previous value of the coefficient. 

59. A method according to Claim 58, wherein each token also indicates if the 
value of the mathematical function associated with the respective sample and 

1 0 coefficient is zero, and wherein said updating step updates the coefficient by adding a 
zero to the previous value of the coefficient if the token indicated that the value of the 
mathematical function is zero. 

60. A method according to Claim 58, wherein each token also indicates if the 
sign of the mathematical function associated with the respective sample and 

1 5 coefficient is positive or negative, wherein said storing in the first memory device step 
comprises storing only pre-calculated values corresponding to the combination of a 
respective sample and the magnitude of a respective mathematical function without 
accounting for the sign of the mathematical function, thereby reducing the number of 
pre-calculated values that are stored by the first memory device. 

20 61 . A method for reducing the number of values that must be stored to 

represent the possible mathematical terms of a function comprising the steps of: 
generating a first list of all possible mathematical terms of the function; 
determining at least one redundant term, if a redundant term is present; and 
storing in a second list all of the unique mathematical terms of the function, 
25 such that the second list does not include at least one of the redundant mathematical 
terms. 

62. A method according to Claim 61, wherein said generating step generates a 
first list of all possible mathematical terms of the function, wherein said determining 
step systematically compares each mathematical term in the list to all other 
30 mathematical terms in the list to determine which of the mathematical terms are 
redundant; and wherein said storing step stores in a second list all of the unique 
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mathematical terms of the function, such that there are no redundant mathematical 
terms of the function in the second list. 

63. A method according to Claim 62, wherein the function is periodic such 
that some of the mathematical terms of the function have the same magnitude and 

5 different signs, wherein said determining step compares the magnitude of each 

mathematical term in the list to the magnitude of each of the other mathematical terms 
in the list to determine which of the mathematical terms have the same magnitude, 
wherein said storing step stores in the second list all of the mathematical terms having 
unique magnitudes, and wherein said method further comprises the step of creating a 

1 0 token associated with each mathematical term, wherein the token indicates the 

magnitude stored in the second list associated with the mathematical term and the sign 
associated with the mathematical term. 

64. A method according to Claim 62, wherein at least one of the mathematical 
terms has a magnitude of zero, wherein said method further comprises creating a 

1 5 token associated with the mathematical term indicating that the mathematical term is 
zero such that said storing step does not store the mathematical term in the second list. 

65. A method according to Claim 62 further comprising the step of addressing 
each of the mathematical terms in the second list, such that the mathematical terms 
may be retrieved. 

20 66. A method according to Claim 62, wherein the function is representative of 

a signal and is defined by samples of the signal, wherein a sample of the signal is one 
of a finite number of possible values, wherein said generating step comprises 
generating the first list of all possible combinations of the possible values of the 
sample and the mathematical terms of the function, wherein said determining step 

25 comprises systematically comparing each combination in the list to all other 

combinations in the list to determine which of the combinations are redundant, and 
wherein said storing step comprises storing in the second list all of the unique 
combinations, such that there are no redundant combinations in the second list. 

67. A computer program product for determining the coefficients of a 
30 function representative of an input signal based on a predetermined plurality of 
samples of the input signal, wherein the computer program product comprises: 
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a computer readable storage medium having computer readable program code 
means embodied in said medium, said computer-readable program code means 
comprising: 

first computer instruction means for receiving samples of the signal; 

5 and 

second computer instruction means for updating at least one of the 
coefficients prior to receipt of the last sample of the plurality samples to thereby 
decrease the latency of the time required to determine the coefficients of the function. 

68. A computer program product according to Claim 67, wherein said first 
1 0 computer instruction means receives each of the samples one at a time, and wherein 
said second computer instruction means updates the coefficients of the function based 
on each sample as the sample is received without awaiting receipt of all samples to 
thereby decrease the latency of the time required to determine the coefficients of the 
function. 

1 5 69. A computer program product according to Claim 68, wherein each 

coefficient is comprised of at least one term that is at least partially based upon a 
combination of a sample and a mathematical function, said computer-readable 
program code means further comprising third computer instruction means for 
determining a respective term of each coefficient by combining each sample upon 

20 receipt with the mathematical function associated with the sample and the coefficient, 
and wherein, for each coefficient, said second computer instruction means updates the 
coefficient by adding the respective term to a previous value of the coefficient. 

70. A computer program product according to Claim 69, wherein each sample 
only contributes to one term of each coefficient, and wherein said second computer 

25 instruction means updates each of the coefficients based on each sample upon receipt 
without requiring the sample to thereafter be stored. 

71. A computer program product according to Claim 69. wherein said second 
computer instruction means updates each of the coefficients with each of the plurality 
of samples as each sample is received, and wherein as each coefficient is updated with 

30 the last of the plurality of samples, second computer instruction means outputs the 
coefficient. 
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72. A computer program product according to Claim 69 further comprising 
fourth computer instruction means for storing a value representing the mathematical 
function associated with each sample and coefficient in a memory device, and 
wherein for each sample and coefficient, said third computer instruction means 

5 accesses the memory device and multiplies the sample by the value representing the 
mathematical function associated with the sample and coefficient to thereby define a 
term, and wherein said second computer instruction means updates the coefficient by 
adding the term to the previous value of the coefficient. 

73. A computer program product according to Claim 72, wherein the memory 
10 device includes an array having a plurality of cells, wherein said fourth computer 

instruction means stores in each cell of the array a value representing the 
mathematical function associated with a respective sample and coefficient, wherein 
each cell of the array has a unique address, which is designated by the respective 
coefficient and sample, and wherein, for each sample and coefficient, said third 
1 5 computer instruction means accesses the cell of the memory device using the address 
associated with the sample and coefficient, multiplies the sample by the stored value 
to thereby define a term, and thereafter said second computer instruction means 
updates the coefficient by adding the term to the previous value of the coefficient. 

74. A computer program product according to Claim 69, wherein each sample 
20 of the signal has a value that is one of a finite number of possible values, wherein said 

computer-readable program code means further comprises fourth computer instruction 
means for storing in a first memory device having an array of cells a pre-calculated 
value corresponding to the combination of one of the finite number of possible values 
of the sample and the mathematical function associated with each coefficient and 
25 sample such that each cell is associated with a respective sample, coefficient, and 
finite value of the sample, and wherein each sell is represented by a token address. 

75. A computer program product according to Claim 74, wherein said 
computer-readable program code means further comprises fifth computer instruction 
means for storing in a second memory device having an array of cells tokens that each 

30 represent a respective coefficient and sample, wherein for each sample said third 
computer instruction means accesses the second memory device and for each 
coefficient, retrieves the token associated with the coefficient, and the sample and 
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supplies the token to the first memory device, and thereafter retrieves the pre- 
calculated value stored in the cell of the first memory device that has an address 
comprised of the token and the value of the sample, and wherein said second 
computer instruction means updates the coefficient by adding the pre-calculated value 
5 from the first memory device to the previous value of the coefficient. 

76. A computer program product according to Claim 74 further comprising 
fifth computer instruction means for addressing the cells of the first memory device, 
wherein for each sample said fifth computer instruction means outputs the token 
associated with the coefficient and the sample to the first memory device, and wherein 
1 0 said third computer instruction means retrieves the pre-calculated value stored in the 
cell of the first memory device that has an address comprised of the token and the 
value of the sample, and wherein said second computer instruction means updates the 
coefficient by adding the pre-calculated value from the first memory device to the 
previous value of the coefficient. 

15 77 . A computer program product according to Claim 76, wherein each token 

also indicates if the value of the mathematical function associated with the respective 
sample and coefficient is zero, and wherein said second computer instruction means 
updates the coefficient by adding a zero to the previous value of the coefficient if the 
token indicated that the value of the mathematical function is zero. 

20 78. A computer program product according to Claim 76. wherein each token 

also indicates if the sign of the mathematical function associated with the respective 
sample and coefficient is positive or negative, wherein said fourth computer 
instruction means stores only pre-calculated values corresponding to the combination 
of a respective sample and the magnitude of a respective mathematical function 

25 without accounting for the sign of the mathematical function, thereby reducing the 
number of pre-calculated values that are stored by the first memory device. 

79. A computer program product according to Claim 76, wherein each token 
represents a respective coefficient and sample, wherein said method further comprises 
sixth computer instruction means for selecting the tokens, wherein to generate 
30 coefficients representing a function that is the inverse of the signal, said sixth 

computer instruction means switches the contents of the token such that the token 
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addresses a cell in the first memory device containing a pre-calculated value 
representing an inverse mathematical function associated with a respective sample 
and coefficient, and wherein said second computer instruction means updates the 
coefficient by adding the pre-calculated value from the first memory device to the 
5 previous value of the coefficient. 

80. A computer program product according to Claim 79, wherein said first 
computer instruction means receives samples one at a time from a plurality of signals 
each present on a separate channel, wherein said third computer instruction means 
receives each of the samples one at a time for each of the signals and based on the 

1 0 tokens from said sixth computer instruction means, said second computer instruction 
means updates the coefficients of the function associated with each sample based on 
each sample associated with the signal as the sample is received, wherein said sixth 
computer instruction means switches the tokens for the samples received from at least 
on of the channels, such that said third computer instruction means generates 

1 5 coefficients representing a function that is the inverse of the signal for at least one 
channel. 

81. a computer program product according to Claim 69, wherein said 
computer-readable program code means further comprises fourth computer instruction 
means for storing each of the samples as they are received in a memory device. 

20 82. A computer program product according to Claim 8 1 , wherein after said 

first computer instruction means has received and said second computer instruction 
means has processed the predetermined plurality of samples, said second computer 
instruction means outputs the coefficients, and wherein when a new sample of the 
input signal is received after the predetermined plurality of samples has already been 

25 received, said computer-readable program code means further comprises fifth 

computer instruction means for subtracting the term based upon a first sample of the 
predetermined plurality of samples from the term based upon the new sample, and 
wherein said second computer instruction means updates the coefficients by the 
difference between the terms based upon the new sample and the first sample of the 

30 predetermined plurality of samples. 
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83. A computer program product according to Claim 81 , wherein after said 
first computer instruction means has received and said second computer instruction 
means has processed the predetermined plurality of samples, said second computer 
instruction means outputs the coefficients, and wherein when a new sample of the 

5 input signal is received after the predetermined plurality of samples have already been 
received, said computer-readable program code means further comprises fifth 
computer instruction means for subtracting the term based upon a first sample of the 
predetermined plurality of samples from each of the coefficients, and wherein said 
second computer instruction means adds the term based upon the new sample to each 
10 of the coefficients. 

84. A computer program product according to Claim 69, wherein there is at 
one preselected coefficient of interest, and wherein said first computer instruction 
means receives each of the samples one at a time and said second computer 
instruction means updates the preselected coefficient of the function based on each 

1 5 sample as the sample is received, such that the preselected coefficient may be 
evaluated independent of the other coefficients. 

85. A computer program product according to Claim 84, wherein said second 
computer instruction means outputs the preselected coefficient each time the 
coefficient is updated. 

20 86. A computer program product according to Claim 84. wherein there are at 

least one first and second preselected coefficients of interest, and wherein said second 
computer instruction means updates the first preselected coefficient of interest with a 
different number of samples than the second preselected coefficient of interest, such 
that the resolution of each preselected coefficient is different. 

25 87. A computer program product according to Claim 69, wherein said first 

computer instruction means receives samples one at a time from a plurality of signals 
each present on a separate channel, wherein said second instruction means receives 
each of the samples one at a time for each of the signals and updates the coefficients 
of the function associated with each sample based on each sample associated with the 

30 signal as the sample is received. 
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88. A computer program product according to Claim 87, wherein said first 
computer instruction means simultaneously receives samples one at a time from a 
plurality of signals each present on a separate channel, wherein said second computer 
instruction means receives each of the samples one at a time for each of the signals 

5 and simultaneously updates the coefficients of the function associated with each 
sample based on each sample associated with the signal as the sample is received. 

89. A computer program product for determining the coefficients of a function 
for a given input signal based on a sample of the input signal, wherein each 
coefficient is comprised of at least one term that is at least partially based upon a 

1 0 combination of the sample and a mathematical function, wherein the computer 
program product comprises: 

a computer readable storage medium having computer readable program code 
means embodied in said medium, said computer-readable program code means 
comprising: 

1 5 first computer instruction means for storing a value representing the 

mathematical function associated with the sample and each coefficient in a first 
memory device; 

second computer instruction means for receiving the sample of the 

input signal; 

20 third computer instruction means for determining a respective term of 

each coefficient by accessing the first memory device, multiplying the sample by the 
value representing the mathematical function associated with the sample and 
coefficient to thereby define a term; and 

fourth computer instruction means for updating each coefficient by 

25 adding the respective term to the previous value of the coefficient. 

90. A computer program product according to Claim 89, wherein the first 
memory device includes an array having a plurality of cells, wherein said first 
computer instruction means stores a value representing the mathematical function 
associated with the sample and a respective coefficient in each cell of the array, 
30 wherein each cell of the array has a unique address, which is designated by the 

respective coefficient and sample, and wherein, for the sample and each coefficient, 
said third computer instruction means accesses the cell of the first memory device 
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using the address associated with the sample and coefficient and multiplies the sample 
by the stored value to thereby define a term, and thereafter said fourth computer 
instruction means updates the coefficient by adding the term to the previous value of 
the coefficient. 

5 9 1 . A computer program product according to Claim 89, wherein the sample of 

the input signal has a value that is one of a finite number of possible values, said first 
computer instruction means stores in a first memory device having an array of cells a 
pre-calculated value corresponding to the combination of one of the finite number of 
possible values of the sample and the mathematical function associated with each 
1 0 coefficient such that each cell contains a pre-calculated value corresponding to the 
combination of one of the finite number of possible values of the sample and the 
mathematical function associated with the respective coefficient, wherein said 
computer-readable program code means comprises fifth computer instruction means 
for storing tokens that each represent a respective coefficient and the sample in a 

1 5 second memory device having an array of cells, and wherein for each sample said 
third computer instruction means accesses the second memory device and retrieves 
the token associated with the coefficient and the sample and supplies the token to the 
first memory device, and thereafter retrieves the pre-calculated value stored in the cell 
of the first memory device that has an address comprised of the token and the value of 

20 the sample, and wherein said fourth computer instruction means updates the 

coefficient by adding the pre-calculated value from the first memory device to the 
previous value of the coefficient. 

92. A computer program product according to Claim 91, wherein each token 
also indicates if the value of the mathematical function associated with the respective 

25 sample and coefficient is zero, and wherein said fourth computer instruction means 
updates the coefficient by adding a zero to the previous value of the coefficient if the 
token indicated that the value of the mathematical function is zero. 

93. A computer program product according to Claim 91 , wherein each token 
also indicates if the sign of the mathematical function associated with the respective 

30 sample and coefficient is positive or negative, wherein said first computer instruction 
means stores in the first memory device step comprises storing only pre-calculated 
values corresponding to the combination of a respective sample and the magnitude of 
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a respective mathematical function without accounting for the sign of the 
mathematical function, thereby reducing the number of pre-calculated values that are 
stored by the first memory device. 

94. A computer program product for reducing the number of values that must 
5 be stored to represent the possible mathematical terms of a function comprising: 

computer readable storage medium having computer readable program code 
means embodied in said medium, said computer-readable program code means 
comprising: 

first computer instruction means for generating a first list of all 
10 possible mathematical terms of the function; 

second computer instruction means for determining at least one 
redundant term, if a redundant term is present; and 

third computer instruction means for storing in a second list all of the 
unique mathematical terms of the function, such that the second list does not include 
1 5 at least one of the redundant mathematical terms. 

95. A computer program product according to Claim 94, wherein said first 
computer instruction means generates a first list of all possible mathematical terms of 
the function, wherein said second computer instruction means systematically 
compares each mathematical term in the list to all other mathematical terms in the list 

20 to determine which of the mathematical terms are redundant, and wherein said third 
computer instruction means stores in a second list all of the unique mathematical 
terms of the function, such that there are no redundant mathematical terms of the 
function in the second list. 

96. A computer program product according to Claim 95, wherein the function 
25 is orthogonal such that some of the mathematical terms of the function have the same 

magnitude and different signs, wherein said second computer instruction means 
compares the magnitude of each mathematical term in the list to the magnitude of 
each of the other mathematical terms in the list to determine which of the 
mathematical terms have the same magnitude, wherein said third computer instruction 
30 means stores in the second list all of the mathematical terms having unique 

magnitudes, and wherein said computer-readable program code means further 
comprises fourth computer instruction means for creating a token associated with 
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each mathematical term, wherein the token indicates the magnitude stored in the 
second list associated with the mathematical term and the sign associated with the 
mathematical term. 

97. A computer program product according to Claim 95, wherein at least one 
5 of the mathematical terms has a magnitude of zero, wherein said computer-readable 

program code means further comprises fourth computer instruction means for creating 
a token associated with the mathematical term indicating that the mathematical term is 
zero such that said storing step does not store the mathematical term in the second list. 

98. A computer program product according to Claim 95, wherein said 

1 0 computer-readable program code means further comprises fourth computer instruction 
means for addressing each of the mathematical terms in the second list, such that the 
mathematical terms may be retrieved. 

99. A computer program product according to Claim 95, wherein the function 
is representative of a signal and is defined by samples of the signal, wherein a sample 

15 of the signal is one of a finite number of possible values, wherein said first computer 
instruction means generates a first list of all possible combinations of the possible 
values of the sample and the mathematical terms of the function, wherein said second 
computer instruction means systematically compares each combination in the list to 
all other combinations in the list to determine which of the combinations are 

20 redundant, and wherein said third computer instruction means stores in a second list 
all of the unique combinations, such that there are no redundant combinations in the 
second list. 

100. A computer program product according to Claim 94 further comprising 
fourth computer instruction means for generating a circuit diagram of a coefficient 

25 generator, wherein the coefficient generator generates the coefficients of a function 
representative of an input signal by updating at least one of the coefficients prior to 
receipt of the last sample of the plurality of samples to thereby decrease the latency of 
the time required to determine the coefficients of the function. 

101 . A computer program product according to Claim 94 further comprising 
30 fourth computer instruction means for generating a computer program, wherein the 

computer program generates the coefficients of a function representative of an input 
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signal by updating at least one of the coefficients prior to receipt of the last sample of 
the plurality of samples to thereby decrease the latency of the time required to 
determine the coefficients of the function. 
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